acgo题库
  • 首页
  • 题库
  • 题单
  • 竞赛
  • 讨论
  • 排行
  • 团队
  • 备赛专区

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
登录
注册
题目详情题解(0)讨论(0)提交记录(0)
  • 【正经题解】关押罪犯

    并查集, 但因为它们带有权值,因此排序是必须的,我们要尽可能让危害大的罪犯在两个监狱里。 那么,再结合敌人的敌人和自己在一个监狱的规律合并。 当查找时发现其中两个罪犯不可避免地碰撞到一起时,只能将其输出并结束。 还有一点很重要,就是没有冲突时一定输出 000

    userId_undefined

    AC君

    管理员
    倔强青铜
    17阅读
    1回复
    2点赞
  • 111

    #include <cstdio> #include <algorithm> using namespace std; struct data {int x,y,z;}; data f[100005]; int n,m,a[20005],b[20005],i; inline bool cmp(data a,data b){return a.z>b.z;} inline int find(int x){ if(a[x]x) return x; a[x]=find(a[x]); return a[x]; } inline void ad(int x,int y){ x=find(a[x]); y=find(a[y]); a[x]=y; } inline bool check(int x,int y){ x=find(x); y=find(y); if(xy) return true; return false; } int main(){ scanf("%d%d",&n,&m); for(i=1;i<=n;i++) a[i]=i; for(i=1;i<=m;i++) scanf("%d%d%d",&f[i].x,&f[i].y,&f[i].z); sort(f+1,f+m+1,cmp); for(i=1;i<=m+1;i++){ if(check(f[i].x,f[i].y)) {printf("%d",f[i].z);break;} else{ if(!b[f[i].x]) b[f[i].x]=f[i].y; else {ad(b[f[i].x],f[i].y);} if(!b[f[i].y]) b[f[i].y]=f[i].x; else {ad(b[f[i].y],f[i].x);} } } }

    userId_undefined

    C++小红帽

    倔强青铜
    7阅读
    0回复
    0点赞
  • 题解

    userId_undefined

    法兰西玫瑰

    倔强青铜
    4阅读
    0回复
    0点赞
首页