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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

【状压DP】十二桥问题(nowcoder 1104-B)

發布時間:2023/12/3 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【状压DP】十二桥问题(nowcoder 1104-B) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

正題

nowcoder 1104-B


題目大意

給你一個無向圖,問你從1開始經過若干必要邊,然后回到1的最短路徑


解題思路

因為關鍵邊較少,先從每個關鍵點跑一遍dij,得出最短距離

fs,if_{s,i}fs,i?表示必要邊的狀態為s,當前在第i個關鍵點的最短距離,然后直接轉移


code

#include<queue> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define ll long long #define N 50010 #define M 200021 #define mp make_pair #define fs first #define sn second using namespace std; ll n,m,k,x,y,z,w,tot,ans,p[N],b[N],h[N],q[30],to[30][30],f[50000][30]; priority_queue<pair<ll,ll> >d; struct rec {ll l,to,nx; }e[M<<1]; struct node {node(ll xx=0,ll yy=0,ll zz=0){x=xx,y=yy,z=zz;}ll x,y,z; }a[30]; void add(ll x,ll y,ll z) {e[++tot].to=y;e[tot].l=z;e[tot].nx=h[x];h[x]=tot;return; } void dij(ll x) {memset(b,127/3,sizeof(b));memset(p,0,sizeof(p));b[x]=0;d.push(mp(0,x));while(!d.empty()){ll u=d.top().sn;d.pop();if(p[u])continue;p[u]=1;for(ll i=h[u];i;i=e[i].nx){ll v=e[i].to;if(b[u]+e[i].l<b[v]){b[v]=b[u]+e[i].l;d.push(mp(-b[v],v));}}}return; } int main() {scanf("%lld%lld%lld",&n,&m,&k);for(ll i=1;i<=m;++i){scanf("%lld%lld%lld",&x,&y,&z);if(i<=k){a[i]=node(x,y,z);q[++w]=x;q[++w]=y;}add(x,y,z);add(y,x,z);}q[++w]=1;sort(q+1,q+1+w);w=unique(q+1,q+1+w)-q-1;for(ll i=1;i<=w;++i){dij(q[i]);//跑最短路for(ll j=1;j<=w;++j)to[i][j]=b[q[j]];}for(ll i=1;i<=k;++i){a[i].x=lower_bound(q+1,q+1+w,a[i].x)-q;a[i].y=lower_bound(q+1,q+1+w,a[i].y)-q;}memset(f,127/3,sizeof(f));f[0][1]=0;for(ll s=0;s<(1<<k)-1;++s)for(ll i=1;i<=k;++i)if(!(s&(1<<i-1)))for(ll j=1;j<=w;++j){f[s|(1<<i-1)][a[i].x]=min(f[s|(1<<i-1)][a[i].x],f[s][j]+min(to[j][a[i].y]+a[i].z,to[j][a[i].x]+a[i].z+to[a[i].y][a[i].x]));//有兩種走的方法f[s|(1<<i-1)][a[i].y]=min(f[s|(1<<i-1)][a[i].y],f[s][j]+min(to[j][a[i].x]+a[i].z,to[j][a[i].y]+a[i].z+to[a[i].x][a[i].y]));}ans=1e15;for(ll i=1;i<=w;++i)ans=min(ans,f[(1<<k)-1][i]+to[i][1]);printf("%lld",ans);return 0; }

總結

以上是生活随笔為你收集整理的【状压DP】十二桥问题(nowcoder 1104-B)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 91大神精品在线 | 无人在线观看高清视频 | 中文字幕欧美激情 | 久久久国产精品x99av | 国偷自产av一区二区三区麻豆 | 国产原创在线观看 | 久久九九精品视频 | 极品探花在线播放 | 涩涩视频免费 | 影音先锋中文字幕一区二区 | 日韩视频中文字幕在线观看 | 欧美日韩亚洲免费 | 亚洲一区成人 | 亚洲成人精品久久久 | 日本美女黄视频 | 欧美亚洲另类小说 | 中文字幕欧美激情 | www.国产高清 | 97福利在线 | 一级淫片免费 | 波多野结衣免费视频观看 | 国产中文视频 | 欧美中文字幕在线观看 | 天天综合天天做 | 欧美精品第二页 | 国产精品三级 | 91国视频| 99久久精品免费 | 黄色片女人 | 91操操操 | 亚洲国产一区二区a毛片 | 国产av人人夜夜澡人人爽麻豆 | 久久99精品久久久水蜜桃 | 干b视频在线观看 | 欧美日本高清视频 | 黄黄的网站| 亚洲经典一区二区三区四区 | 欧美肉大捧一进一出免费视频 | 色妞www精品视频 | 国产片天天弄 | 国产极品美女在线 | 亚洲日本精品一区 | 桥本有菜aⅴ一区二区三区 在线午夜电影 | 国产人伦精品一区二区三区 | 99九九视频 | 伊朗做爰xxxⅹ性视频 | 美女爽爽爽 | 欧美黑粗硬 | 天天看天天操 | 涩涩屋视频在线观看 | 黄在线视频 | 日韩黄色高清视频 | 中文字幕在线观看线人 | 欧美成人三级在线观看 | 超黄网站在线观看 | wwwxxx黄色片 | 日本国产在线观看 | 色窝窝综合色窝窝久久 | 中文字幕精品三级久久久 | 黄色大全免费看 | 日本在线免费观看视频 | 国产精品国产三级国产专播品爱网 | 亚洲国产精品无码久久久 | 婷婷亚洲综合 | 一区二区三区在线免费视频 | 亚洲永久精品一区 | 日韩r级在线观看 | 亚洲最大看欧美片网站 | 青青草91视频| 男女做事网站 | 国产一级做a爰片久久毛片男 | 国产视频一区二区三区在线观看 | a级黄片毛片| 无码人妻精品一区二区三区99不卡 | 色欧美88888久久久久久影院 | 蜜桃av鲁一鲁一鲁一鲁俄罗斯的 | av色噜噜 | 亚洲精久久 | 九九九热视频 | 老司机久久 | 日本精品二区 | 国模一区二区三区 | 亚洲在线免费观看视频 | 91av在线免费视频 | 爱情岛av| 在线观看污网站 | 亚洲黄在线观看 | 国产精品毛片一区二区三区 | 国产嫩草av| 久草福利资源在线 | www.日韩av| 日韩视频免费在线观看 | 欧美理伦少妇2做爰 | 成人六区| 欧美a一级片 | 播放黄色一级片 | 99在线视频观看 | 国产极品福利 | 黑人高潮一区二区三区在线看 |