学习笔记:拓扑排序c++两种模板

洛谷经典题目:

P4017 最大食物链计数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)icon-default.png?t=M85Bhttps://www.luogu.com.cn/problem/P4017

模板一(类似于广搜,平常大多用的都是广搜):

#include
#include
#include
#include
using namespace std;
const int mod=80112002;
int n,m;
int dp[5001];
int indegree[5001],oudegree[5001];
vector g[5001];
void toposort(){
	queue q;
	for(int u=1;u<=n;u++)
		if(!indegree[u]){
			q.push(u);
			dp[u]=1;
	}
	while(!q.empty()){
		int u=q.front();
		q.pop();
		for(int i=0;i>n>>m;
   	for(int i=1;i<=m;i++){
   		int u,v;
   		cin>>u>>v;
   		g[u].push_back(v);
   		indegree[v]++;
   		oudegree[u]++;
	   }
	toposort();
	long long ans=0;
	for(int u=1;u<=n;u++)
		if(!oudegree[u])
			ans=(ans+dp[u])%mod;
	cout<

模板二(在竞赛入门经典书里面学到的,深搜):

#include
#include
#include
using namespace std;
const int mod=80112002;
int n,m,t;
int dp[5001];
int vis[5001],indegree[5001],oudegree[5001];
vector g[5001];

bool dfs(int u){
	vis[u]=-1;
	for(int i=0;i>n>>m;
   	for(int i=1;i<=m;i++){
   		int u,v;
   		cin>>u>>v;
   		g[u].push_back(v);
   		indegree[v]++;
   		oudegree[u]++;
	   }
	for(int u=1;u<=n;u++)
		if(!oudegree[u]) dp[u]=1;
	toposort();
	long long ans=0;
	for(int u=1;u<=n;u++)
		if(!indegree[u])
			ans=(ans+dp[u])%mod;
	cout<

你可能感兴趣的:(个人记录,洛谷-java题解,洛谷,c++,学习,开发语言,拓扑学,排序算法)