Sir,what is wrong in my logic.only testcase 1 is pass

#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";
	
 }

Hey Dinesh!

  1. In findcost function, should go from 1 to v.
  2. Don’t increment count in for loop in dfs function!