关注
求问D为什么建返图就会WA,建正图才能AC。 正图代码 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<vector>
#include<cstring>
#include<cstdlib>
#include<iomanip>
#include<ctime>
#include<string>
#include<bitset>
#define D(x) cout<<#x<<" = "<<x<<" "
#define E cout<<endl
using namespace std;
typedef long long ll;
typedef pair<int,int>pii;
const int maxn=100000+5;
const int maxm=200000+5;
const int INF=0x3f3f3f3f;
const ll mod=20010905;
int n,m;
int head[maxn],tot=1;
int in[maxn];
ll d[maxn];
queue<int>q;
struct node{
int from,to,c;
}edge[maxm];
void add(int from,int to){
edge[++tot].from=head[from],head[from]=tot,edge[tot].to=to;
}
void dp(){
d[1]=1;
q.push(1);
while(q.size()){
int x=q.front();q.pop();
for(int i=head[x];i;i=edge[i].from){
int y=edge[i].to;
d[y]=(d[y]+d[x])%mod;
if(--in[y]==0){
q.push(y);
}
}
}
printf("%lld",d[n]%mod);
}
int main() {
// ios::sync_with_stdio(false); freopen("DDoS.in","r",stdin);
scanf("%d%d",&n,&m);
int from,to,c;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&from,&to,&c);
add(from,to);
in[to]++;
}
dp();
return 0;
} 反图代码 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<vector>
#include<cstring>
#include<cstdlib>
#include<iomanip>
#include<ctime>
#include<string>
#include<bitset>
#define D(x) cout<<#x<<" = "<<x<<" "
#define E cout<<endl
using namespace std;
typedef long long ll;
typedef pair<int,int>pii;
const int maxn=100000+5;
const int maxm=200000+5;
const int INF=0x3f3f3f3f;
const ll mod=20010905;
int n,m;
int head[maxn],tot=1;
int in[maxn];
ll d[maxn];
queue<int>q;
struct node{
int from,to,c;
}edge[maxm];
void add(int from,int to){
edge[++tot].from=head[from],head[from]=tot,edge[tot].to=to;
}
void dp(){
d[n]=1;
q.push(n);
while(q.size()){
int x=q.front();q.pop();
for(int i=head[x];i;i=edge[i].from){
int y=edge[i].to;
d[y]=(d[y]+d[x])%mod;
if(--in[y]==0){
q.push(y);
}
}
}
printf("%lld",d[1]%mod);
}
int main() {
// ios::sync_with_stdio(false);
// freopen("DDoS.in","r",stdin);
scanf("%d%d",&n,&m);
int from,to,c;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&from,&to,&c);
add(to,from); //反图
in[from]++;
}
dp();
return 0;
}
查看原帖
1 评论
相关推荐
03-13 14:39
门头沟学院 大数据开发工程师 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 春招/暑实第一面是哪家? #
3692次浏览 43人参与
# 面试官最爱问的 AI 问题是...... #
2404次浏览 83人参与
# 如何一边实习一边找下家? #
2119次浏览 37人参与
# 机械制造面试点评 #
90231次浏览 481人参与
# 跟HR说什么能被秒回? #
1915次浏览 34人参与
# 你的嫡系AI是哪个? #
960次浏览 30人参与
# 你现在的工作,是“成长”还是“消耗”? #
3901次浏览 66人参与
# 现在入门AI应该走哪些方向? #
930次浏览 26人参与
# 你收到了哪些公司的笔试? #
4633次浏览 23人参与
# 找不到好工作选择GAP真的丢人吗 #
102364次浏览 1020人参与
# 你认为小厂实习有用吗? #
127767次浏览 703人参与
# 金三银四,你的春招进行到哪个阶段了? #
19535次浏览 264人参与
# 滴滴笔试 #
38281次浏览 215人参与
# 我的岗位说明书 #
316696次浏览 2784人参与
# 通信硬件公司爆料 #
200301次浏览 550人参与
# 哪些公司真双非友好? #
67381次浏览 281人参与
# 实习进度记录 #
1219188次浏览 11858人参与
# 职场上哪些行为很加分? #
339481次浏览 3791人参与
# 你上一次加班是什么时候? #
139938次浏览 780人参与
# 美团笔试 #
709416次浏览 4691人参与
查看9道真题和解析