社区讨论

求调

P2935[USACO09JAN] Best Spot S参与者 4已保存回复 16

讨论操作

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

当前回复
16 条
当前快照
1 份
快照标识符
@mlkwo0yc
此快照首次捕获于
2026/02/13 21:10
6 天前
此快照最后确认于
2026/02/14 13:52
5 天前
查看原帖
CPP
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=503;
int p,f,c;
int e[N][N];
int a[N];
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0),cout.tie(0);
	cin>>p>>f>>c;
	for(int i=1;i<=f;i++) cin>>a[i];
    memset(e,0x3f3f,sizeof e);
    for(int i=1;i<=c;i++){
        int u,v,w;
        cin>>u>>v>>w;
        e[u][v]=w;
		e[v][u]=w;
    }
    for(int k=1;k<=p;k++){
        for(int i=1;i<=p;i++){
            for(int j=1;j<=p;j++){
                e[i][j]=min(e[i][j],e[i][k]+e[k][j]);
            }
        }
    }
    int idx=-1;
    double ans=9999999999;
    for(int i=1;i<=p;i++){
        double cnt=0;
        bool st=1;
        for(int j=1;j<=f;j++){
        	if(i==j){st=0;break;}
            cnt+=e[i][a[j]];
        }
        if(!st)continue;
        cnt/=double(f);
        if(cnt<ans){
        	idx=i,ans=cnt;
		}
    }
    cout<<idx<<endl;
    return 0;
}

回复

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

正在加载回复...