关于求图的拓扑排序问题之bfs
```c++
#include<iostream>
#include<cstring>
using namespace std;
const int N=1e5+10;
int h[N],e[N],ne[N],idex,n,m,q[N],d[N];
void add(int a,int b){
e[idex]=b;
ne[idex]=h[a];
h[a]=idex;
idex++;
}
bool topsort(){
int hh=0,tt=-1;
for(int i=1;i<=n;i++){
if(!d[i]) q[++tt]=i;
}
while(hh<=tt){
//首先拿出队头元素
int t=q[hh++];
//进行拓展
for(int i=h[t];i!=-1;i=ne[i]){
int j=e[i];
if(--d[j]==0) q[++tt]=j;
}
}
//检查进队了多少个元素
return tt==n-1;
}
int main(){
cin>>n>>m;
memset(h,-1,sizeof(h));
while(m--){
int x,y;
cin>>x>>y;
add(x,y);
d[y]++;
}
if(topsort()){
for(int i=0;i<n;i++) cout<<q[i]<<" ";
cout<<endl;
}
else printf("-1\n");
return 0;
}
为什么在上述代码之中将
for(int i=h[t];i!=-1;i=ne[i]){
int j=e[i];
if(--d[j]==0) q[++tt]=j;
}
改成
```c++
for(int i=h[t];i!=-1;i=ne[i]){
int j=e[i];
if(!d[j]) d[j]--;
if(d[j]==0) q[++tt]=j;
}
之后运行结果是错误的呢