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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

B监狱 noip 模拟 7.29(区间DP)

發(fā)布時間:2024/9/5 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 B监狱 noip 模拟 7.29(区间DP) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?

監(jiān)獄
題目描述 有一座監(jiān)獄,有N個牢房,N個牢房呈一字排成一排的。也就是說,第i個牢房緊挨著第i+1個(除了末尾那個)。每個牢房里都關押著一名罪犯,總共N名罪犯。
??? 上級要求將某些罪犯釋放,給了一份名單,要求每天釋放一個人。
??? 位于相鄰牢房的罪犯,他們互相之間可以談話也可以傳話,這就使得這里的N名罪犯都可以相互聊天。如果有一個人離開了,那么能和說他上話的人就會很狂躁。如果想讓他們安靜下來,看守必須給狂躁的人吃一頓火鍋。但看守們希望送火鍋的次數(shù)越少越好。請你計算需要送火鍋的次數(shù)。
123 輸入格式 第一行兩個數(shù)N和M,M表示要釋放名單上的人數(shù);
第二行M個數(shù),表示釋放哪些人
12 輸出格式 僅一行,表示最少要給多少人次送火鍋吃。
1 樣例輸入 20 3
3 6 14
12 樣例輸出 35 這道題我真的是想了很久QAQ 開先打了個70 分算法 一直糾結 O(m^3) 算法 網(wǎng)上找了好久 題解也看了 很多 終于悟出了一些小細節(jié) 方法一: 定義 f[i][j] 表示 i 到 j 號 囚犯已經(jīng)被釋放 注意 是被釋放的囚犯? 所以 對于 每一個小區(qū)間的狀態(tài)都是 于原區(qū)間一樣? 那么i號釋放的代價 為 他左右兩邊 的沒有釋放資格的囚犯數(shù) 所以枚舉斷點 k K 將 i 到 j 分成 區(qū)間 [i,k-1] [k+1,j]? 對于每個區(qū)間 都已經(jīng)被算好了 k 就是第一個來更新 [i,j]的 才會 把 [i,j] 分成兩個獨立的區(qū)間 所以代價為 a[j+1]-a[i-1]-2 (這里想了很久,其實想想也是? 對于區(qū)間 [i,j] 是釋放囚犯的集合 他其實包含了沒有釋放資格的囚犯 a[j+1]-a[i-1]-2 是 i- 1號釋放囚犯 和 j+1 號釋放囚犯間的 人數(shù)) -2? 因為 自己不更新? 所以我們有狀態(tài)轉(zhuǎn)移方程? f[i][j]=min(f[i][j],f[i][k-1]+f[k+1][j]+a[j+1]-a[i-1]-2); 時間復雜度 O(M^3) 某ruan姓同學思路: 枚舉k∈[i,j],k是區(qū)間[i,j]內(nèi)第一個被放出去的囚犯,這個區(qū)間內(nèi)本來有a[j+1]-a[i-1]-1個囚犯,放出去一個之后剩下a[j+1]-a[i-1]-2個囚犯都要吃火鍋

然后區(qū)間[i,j]被分成了[i,k-1]和[k+1,j]

因為第k個囚犯被放出去了 code: // #include<stdio.h> #include<bits/stdc++.h> using namespace std; #define maxnn 4002 int f[maxnn][maxnn]; int n,m; int a[101]; int s[maxnn][maxnn]; int sum[maxnn]; int res[maxnn]; int main() {cin>>n>>m;for(int i=1;i<=m;i++){cin>>a[i];}sort(a+1,a+1+m);a[m+1]=n+1;for(int i=m;i>=1;i--)for(int j=i;j<=m;j++){ f[i][j]=1e9;for(int k=i;k<=j;k++)f[i][j]=min(f[i][k-1]+f[k+1][j]+a[j+1]-a[i-1]-2,f[i][j]);}cout<<f[1][m]; }

至于為甚么 a[m+1]=n+1;因為 n節(jié)點不是一個有釋放資格的囚犯

方法2: f[i][j]表示將第i個區(qū)間到第j個區(qū)間的人全部合并的最小代價 那么對于f[i][j],我們就可以枚舉中間區(qū)間mid
那么f[i][j]的求值表達是就是 f[i][j]=min(f[i][j],f[i][mid]+f[mid+1]][j]+sum[j]-sum[i-1]-2){其中i<=mid<j} 解釋一下
f[i][mid]+f[mid+1][j]表示的是之前進去的人請吃的火鍋
sum[j]-sum[i-1]-1表示的是這一整段區(qū)間的人數(shù)之和
因為請吃火鍋的這個人本身不吃,所以還要-1 得到==>f[i][mid]+f[mid+1][j]+sum[j]-sum[i-1]-2 合并區(qū)間!!? 式子+代價 https://blog.csdn.net/qq_37920580/article/details/77936432

轉(zhuǎn)載于:https://www.cnblogs.com/OIEREDSION/p/11279740.html

總結

以上是生活随笔為你收集整理的B监狱 noip 模拟 7.29(区间DP)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 成人免费版欧美州 | 91精品视频在线看 | 日本久久黄色 | 一区二区视频在线 | 成人性生生活性生交全黄 | 男人操女人下面视频 | 日日干av| 精品一区二区三区四区 | 久久久久国产一区二区三区 | 国产精品伦子伦免费视频 | 强睡邻居人妻中文字幕 | 伊人成人22| 香蕉性视频 | 超级碰在线视频 | 中文字幕av观看 | 国产丝袜在线播放 | 欧美特级一级片 | 黄色美女片 | 精品国产乱码久久久久久郑州公司 | www视频在线免费观看 | 精品国产欧美日韩 | 国产精品无码久久久久久电影 | 毛片一级在线观看 | 影音先锋男人的天堂 | 韩国一级淫片免费看 | 三级精品在线 | 久久免费精彩视频 | 奇米影视四色7777 | 午夜精品久久久 | 国产伦精品一区二区三区 | 欧美性猛交xx乱大交 | 欧美在线v | 国产在线观看黄色 | 2025国产精品 | 深田咏美av在线 | 午夜精品在线播放 | 老熟妻内射精品一区 | 金鱼妻日剧免费观看完整版全集 | av青青草| 日韩激情文学 | 99精品久久99久久久久 | 极品在线观看 | 国产特级片 | www.人人干 | 国产偷啪 | 亚洲第一黄色网 | 亚洲日日操 | 亚洲一区二区三区黄色 | 伊人网欧美 | 色偷偷网站 | 黄色网址进入 | 在线一区不卡 | 欧美一区二区三区色 | 国产一区日韩一区 | 日韩成人在线观看 | 9191av| 亚洲一区二区自拍 | 亚洲天堂成人在线观看 | 国产毛片91 | 亚洲欧洲在线视频 | 色亚洲色图 | 五月婷丁香 | 熟女俱乐部一区二区 | 青草久久网 | 亚洲热在线视频 | 日韩日日日 | 99久久精品免费看国产免费软件 | 色欧洲| 成人av网站在线观看 | 国产精品国产三级国产aⅴ9色 | 久久精品在线视频 | 国产亚洲欧美视频 | 国内黄色片 | 亚洲成av人片在线观看无码 | 日韩精品视频在线 | 国产91精品一区二区 | 日韩少妇一区二区三区 | 中文无码熟妇人妻av在线 | 日本簧片在线观看 | 日韩第一色| 国产精品久久久久毛片 | 97伊人超碰 | 99久久久 | 亚洲免费av一区 | 色综合久久五月 | 成年人视频免费 | 精品久久中文字幕 | 国产精品久久久久毛片大屁完整版 | 少妇肥臀大白屁股高清 | 99精品视频免费在线观看 | 免费看污视频的网站 | 激情综合视频 | 色片在线播放 | 春色影视 | 中文在线资源 | 色多多导航| 人妻丰满熟妇av无码久久洗澡 | 一区二区三区四区久久 | 污网站在线免费看 |