社区讨论

求差错嘟嘟噜

P1078[NOIP 2012 普及组] 文化之旅(疑似错题)参与者 6已保存回复 5

讨论操作

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

当前回复
5 条
当前快照
1 份
快照标识符
@mi6yra99
此快照首次捕获于
2025/11/20 13:01
4 个月前
此快照最后确认于
2025/11/20 13:01
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,k,m,s,t,ral[101],lea[1001],vis[1001],vvis[101];
int road[110][110];
int ans=1<<30;
vector<pair<int,int> >cou[111];
void dfs(int now,int cost)
{
	//更新答案. 
	if(now==t){
		ans=min(ans,cost);
		return ;
	}
	//最优化剪枝. 
	if(cost>ans)return ;
	for(int i=0;i<cou[now].size();++i){
		int a=cou[now][i].first;
		int b=cou[now][i].second;
		if(vis[lea[a]]||vis[lea[ral[a]]])continue;
		vis[lea[a]]=1;
		dfs(a,cost+b);
		vis[lea[a]]=0;
	}
	return ;
}
int main()
{
	cin>>n>>k>>m>>s>>t;
	int c;
	//i国的文化为lea[i]. 
	for(int i=1;i<=n;++i){
		scanf("%d",&c);
		lea[i]=c;
	}
	
	for(int i=1;i<=k;++i){
		for(int j=1;j<=k;++j){
			scanf("%d",&c);
			if(c)ral[i]=j;            
		}
	} 
	
	int u,v,d;
	for(int i=1;i<=m;++i){
		scanf("%d%d%d",&u,&v,&d);
		//u到v的距离为d.
		if(road[u][v]&&road[v][u]){
			road[u][v]=min(road[u][v],d);
			road[v][u]=min(road[v][u],d);
		}
		else{
			road[u][v]=d;
			road[v][u]=d;
		} 
	}
	for(int i=1;i<=n;++i){
		for(int j=1;j<=n;++j){
			if(road[i][j]){
				cou[i].push_back(make_pair(j,road[i][j]));
			}
		}
	}
	vis[lea[s]]=1;
	dfs(s,0);
	if(ans!=(1<<30))cout<<ans<<endl;
	else puts("-1");
	return 0;
}

回复

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

正在加载回复...