Algoritmul este exact acelasi cu sursa de 50 de puncte...si totusi primesc doar 5

...ma poate lamuri cineva?

,Am incercat sa implementez si listele de adiacenta si primesc doar 10 puncte..
#include <iostream>
#include <cstdio>
#define Nmax 1001
using namespace std;
int n,i,j,cmp=0;
int a[Nmax][Nmax];
bool viz[Nmax];
void citire(int &n)
{
int m;
freopen("dfs.in","r",stdin);
freopen("dfs.out","w",stdout);
scanf("%d %d",&n,&m);
int x,y;
for(i=1;i<=m;++i)
{
scanf("%d %d",&x,&y);
a
a[y]
}
}
void dfs(int x)
{
viz
for(i=1;i<=n;++i)
if (!viz
&& a}
int main()
{
citire(n);
for(i=1;i<=n;++i)
if (!viz) {++cmp;dfs(i);}
printf("%d",cmp);
return 0;
}