社区讨论

帮忙找bug

P3183[HAOI2016] 食物链参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@luv760n7
此快照首次捕获于
2024/04/11 20:10
2 年前
此快照最后确认于
2024/04/11 21:36
2 年前
查看原帖
CPP
#include <iostream>
#include <cstdio>
#include <algorithm> 
#include <vector>
#include <cstring>
using namespace std;
const int cre = 1e5+1;
const int maxn = 1e5+1e5+1;
int n, m;
vector<int> g[cre];
int a[maxn], b[maxn];
int inner[maxn], outer[maxn];
int st[maxn], s=0, ed[maxn], e=0;	//起点和终点 
int ans=0;
bool check(int d) {
	for(int i=1; i<=e; i++)
		if(ed[i] == d)
			return true;
	return false;
}
int num;
void dfs(int d) {
	if(check(d))
		return ;
	for(int i=0; i<g[d].size(); i++) {
		int k = g[d][i];
		if(outer[k] != 0) {
			num*=outer[k];
			dfs(k);
			num/=outer[k];			
		}
	}
}
int main() {
	scanf("%d%d", &n, &m);
	for(int i=1; i<=m; i++) {
		scanf("%d%d", &a[i], &b[i]);
		g[a[i]].push_back(b[i]); 
		outer[a[i]] ++;
		inner[b[i]] ++;
	}
	for(int i=1; i<=n; i++) {
		if(outer[i]==0 && inner[i] > 0) {
			e++;
			ed[e] = i;
		}	//是食物链底端 
		if(inner[i]==0 && outer[i] > 0) {
			s++;
			st[s] = i;
		}	//是食物链顶端 
	}
	for(int i=1; i<=s; i++) {
		num = outer[st[i]];
		dfs(st[i]);
		ans += num;	
	}
	printf("%d", ans);
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...