社区讨论
求差错嘟嘟噜
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 条回复,欢迎继续交流。
正在加载回复...