#include
#include
using namespace std;
long long int sum=0;
void insertedge(vectoradj[],long long int u,long long int v){
adj[u].push_back(v);
adj[v].push_back(u);
}
void printedge(vectoradj[],long long int v){
for(int i=0;i<v;i++){
for(int j=0;j<adj[i].size();j++){
cout<<i<<" β<<adj[i][j]<<β β;
}
cout<<β\n";
}
}
void dfs(vectoradj[],long long int v,long long int vis[],int &count){
for(int j=0;j<adj[v].size();j++){
if(vis[adj[v][j]]==0){
count=count+1;
vis[adj[v][j]]=1;
dfs(adj,adj[v][j],vis,count);
}
}
}
long long int findcost(vectoradj[],long long int v){
long long int vis[v]={0};
for(int j=0;j<v;j++){
if(vis[j]==0){
int count=0;
dfs(adj,j,vis,count);
sum=sum+(v-count)*count;
count=0;
}
}
return sum;
}
int main(){
int a,b;
cin>>a>>b;
vectoradj[a+1];
for(int j=0;j<b;j++){
long long int u,v;
cin>>u>>v;
insertedge(adj,u,v);
}
cout<<findcost(adj,a)/2<<"\n";
}