日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Codeforces Round #715 (Div. 1) C. Complete the MST 补图 + 思维 + 最小生成树

發布時間:2023/12/4 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Codeforces Round #715 (Div. 1) C. Complete the MST 补图 + 思维 + 最小生成树 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

傳送門

文章目錄

  • 題意:
  • 思路

題意:

給你一張nnn個點mmm個邊的圖,mmm條邊是給定的,要求你給未給定的邊賦值一個邊權,使得所有邊權異或和為000,求所有滿足這種情況的圖中最小生成樹邊權和最小的,輸出最小生成樹的邊權和。

思路

我們先假設多余的邊邊權都為000,已經有的邊的異或和為sumxorsum_{xor}sumxor?,加上多余的邊跑最小生成樹后如果還有多余的邊不在生成樹中,那么答案顯然為當前MSTMSTMST的權值,因為我們可以選一條不在MSTMSTMST中的邊讓他的權值為sumxorsum_{xor}sumxor?。否則多余的邊都在生成樹里,那么一個最優的情況一定是選出一條多余的邊使其邊權為sumxorsum_{xor}sumxor?,其他的邊權為000
那么我們拿出來多余的邊,即原圖的補圖,找到補圖中所有的聯通塊,之后再用本來就有的邊將聯通塊聯通,當前的答案為ansansans,現在我們需要判斷一下是否有多余的邊剩下,這個可以算一下rest=n?(n?1)2?mrest=\frac{n*(n-1)}{2}-mrest=2n?(n?1)??m,讓后每加一條邊就讓rest??rest--rest??,最后看看是否rest>0rest>0rest>0即可,如果剩下了直接輸出ansansans,否則我們需要找到一條多余的邊使其邊權為sumxorsum_{xor}sumxor?,我們可以枚舉原圖的邊,來判斷一下能否用原圖中的邊替代來讓答案邊的更小,注意我們上面連接補圖的聯通塊的邊不能被替代。

// Problem: C. Complete the MST // Contest: Codeforces - Codeforces Round #715 (Div. 1) // URL: https://codeforces.com/problemset/problem/1508/C // Memory Limit: 256 MB // Time Limit: 3000 ms // // Powered by CP Editor (https://cpeditor.org)//#pragma GCC optimize("Ofast,no-stack-protector,unroll-loops,fast-math") //#pragma GCC target("sse,sse2,sse3,ssse3,sse4.1,sse4.2,avx,avx2,popcnt,tune=native") //#pragma GCC optimize(2) #include<cstdio> #include<iostream> #include<string> #include<cstring> #include<map> #include<cmath> #include<cctype> #include<vector> #include<set> #include<queue> #include<algorithm> #include<sstream> #include<ctime> #include<cstdlib> #define X first #define Y second #define L (u<<1) #define R (u<<1|1) #define pb push_back #define mk make_pair #define Mid (tr[u].l+tr[u].r>>1) #define Len(u) (tr[u].r-tr[u].l+1) #define random(a,b) ((a)+rand()%((b)-(a)+1)) #define db puts("---") using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); } //void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); } //void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL; typedef unsigned long long ULL; typedef pair<int,int> PII;const int N=1000010,mod=1e9+7,INF=0x3f3f3f3f; const double eps=1e-6;int n,m; int p[N]; LL rest,xr; bool st[N]; set<int>v[N],all; struct Node {int a,b,w,flag; bool operator < (const Node &W) const {return w<W.w;} }edge[N];int find(int x) {return x==p[x]? x:p[x]=find(p[x]); }void get_block() {queue<int>q;vector<int>now;for(int i=1;i<=n;i++) {if(!st[i]) {q.push(i); st[i]=1;all.erase(i);while(q.size()) {int u=q.front(); q.pop();now.clear();for(auto x:all) {if(v[u].count(x)) continue;q.push(x); now.pb(x);st[x]=1; p[x]=u;rest--;}for(auto x:now) all.erase(x);}}} }int main() { // ios::sync_with_stdio(false); // cin.tie(0);cin>>n>>m;rest=1ll*n*(n-1)/2-m;for(int i=1;i<=n;i++) all.insert(i),p[i]=i;for(int i=1;i<=m;i++) {int a,b,c; scanf("%d%d%d",&a,&b,&c);edge[i]={a,b,c,0};v[a].insert(b); v[b].insert(a);xr^=c;}get_block();sort(edge+1,edge+1+m);LL ans=0;for(int i=1;i<=m;i++) {int a=edge[i].a,b=edge[i].b,w=edge[i].w;a=find(a); b=find(b);if(a==b) continue;p[a]=b; ans+=w; edge[i].flag=1;}if(rest>0) {printf("%lld\n",ans);return 0;}for(int i=1;i<=n;i++) p[i]=i;for(int i=1;i<=m;i++) {int a=edge[i].a,b=edge[i].b,w=edge[i].w;a=find(a); b=find(b);if(a==b) continue;p[a]=b; if(!edge[i].flag) xr=min(xr,1ll*w);}printf("%lld\n",ans+xr);return 0; } /**/

總結

以上是生活随笔為你收集整理的Codeforces Round #715 (Div. 1) C. Complete the MST 补图 + 思维 + 最小生成树的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产成人亚洲综合 | 日韩欧美综合在线 | 国产重口老太伦 | av一卡二卡 | 婷婷丁香社区 | 夫妻自拍偷拍 | 一道本av在线 | 男女视频免费观看 | 六月激情综合网 | 国产欧美精品aaaaaa片 | 九九九九九伊人 | 新版天堂资源中文8在线 | 国产一区二区网址 | 台湾a级艳片潘金莲 | 免费观看一区二区三区毛片 | 亚洲丝袜一区 | 色撸撸在线 | 一区二区自拍 | 九九九九九九精品 | 久久久国产片 | 久久香蕉影院 | 孕妇爱爱视频 | 久久精品韩国 | 狠狠操天天操 | 69堂视频 | 九九精品在线观看 | 伊人影院亚洲 | 精产国品一区二区 | 熟女丰满老熟女熟妇 | 91高跟黑色丝袜呻吟在线观看 | wwwyoujizz日本 | 91水蜜桃 | 久久夜色精品国产欧美乱 | 久久综合成人 | 欧洲一区二区视频 | 97色综合 | 麻豆精品久久 | 日韩亚洲国产欧美 | 69国产在线 | 男男play呻吟动漫网站 | 国产女人18毛片水真多 | 日本人妖在线 | 国产草草浮力影院 | 亚洲天堂v| 日韩国产精品一区二区三区 | 日本美女黄色大片 | 亚洲综合小说 | 久操国产视频 | 日韩av影音先锋 | 久久精品人妻一区二区 | www国产亚洲精品久久网站 | 亚洲天堂三区 | 亚洲自偷自偷偷色无码中文 | 波多野结衣办公室33分钟 | 神秘电影永久入口 | av色吧| a级大片免费看 | 欧美日韩一区不卡 | 青青草精品 | 中文字幕一区二区三区精品 | 亚洲成人国产 | 夜夜视频 | 久草影音 | 日本精品三级 | 日日摸日日干 | 亚洲欧美日韩成人在线 | 91高跟黑色丝袜呻吟在线观看 | 泽村玲子av | 精品三级在线 | 久久久穴 | 国产在线播放一区二区三区 | 久久91亚洲人成电影网站 | 人妻妺妺窝人体色www聚色窝 | 日韩不卡免费视频 | 欧美一级在线视频 | 日韩人妻无码精品久久久不卡 | 黄色香港三级三级三级 | 黄色视屏免费 | 人人干av| 强伦人妻一区二区三区 | 夜夜se| 欧美人与牲动xxxx | 国产综合视频一区二区 | 蜜桃va | 中文字幕日韩精品一区 | 中文字幕+乱码+中文乱 | 欧美性受xxxx黑人猛交88 | 很色的网站 | 亚洲福利视频一区二区三区 | 豆花在线视频 | 欧美日韩精品区别 | 特黄特色大片免费 | 中文字幕av在线免费 | 天天躁夜夜躁狠狠躁 | 99久免费精品视频在线观78 | 国内外成人免费视频 | 啪啪.com| a v视频在线观看 | 免费处女在线破视频 |