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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

刷题总结——拆网线(noip模拟 贪心)

發布時間:2025/5/22 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 刷题总结——拆网线(noip模拟 贪心) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目:

? 給定一顆樹··在保證有k個點與其它點連接的情況下問最少保留多少條邊····

? 樹的節點樹n和k均小于100000;

題解:

? 很容易看出來我們要盡量保留那種一條邊連兩個節點的情況····

? 然后考試的時候我以為這就完了··xjb貪完心后錯了一大半····

? 下次一定要寫對拍了,艸

? 貪心的時候我們要沿著葉子節點來貪心···這樣就能保證正確性了···證明的話就不細說了··不信的話打個對拍看看···

代碼:

??

#include<iostream> #include<cstdio> #include<cstdlib> #include<cmath> #include<ctime> #include<cctype> #include<string> #include<cstring> #include<algorithm> using namespace std; const int N=1e5+5; int T,n,K,fst[N],nxt[N*2],go[N*2],tot,cnt,keep; bool del[N]; inline int R() {char c;int f=0;for(c=getchar();c<'0'||c>'9';c=getchar());for(;c<='9'&&c>='0';c=getchar()) f=(f<<3)+(f<<1)+c-'0';return f; } inline void comb(int a,int b) {nxt[++tot]=fst[a],fst[a]=tot,go[tot]=b;nxt[++tot]=fst[b],fst[b]=tot,go[tot]=a; } inline void pre() {cnt=tot=keep=0;memset(fst,0,sizeof(fst));memset(del,false,sizeof(del)); } inline void dfs(int u,int fa) {for(int e=fst[u];e;e=nxt[e]){int v=go[e];if(v==fa) continue;dfs(v,u);if(!del[v]&&!del[u]){if(keep<K){keep+=2;cnt++;del[v]=del[u]=true;}}} } int main() {//freopen("a.in","r",stdin);T=R();int a; while(T--) {n=R(),K=R();pre();for(int i=1;i<n;i++) a=R(),comb(i+1,a);dfs(1,0);if(keep>=K) cout<<cnt<<"\n";else cout<<cnt+(K-keep)<<"\n";}return 0; }

?

轉載于:https://www.cnblogs.com/AseanA/p/7718675.html

總結

以上是生活随笔為你收集整理的刷题总结——拆网线(noip模拟 贪心)的全部內容,希望文章能夠幫你解決所遇到的問題。

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