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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

【POJ1821】Fence

發布時間:2024/10/12 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【POJ1821】Fence 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

單調隊列優化dp

我們將每個人的s值排序,這樣我們就能保證當前這個人刷的木板一定在上一個人之后,我們就能進行線型dp

定義f[i][j]表示前i個人刷前j個木板獲得的最多報仇,那么有

  • 第i個人不工作,此時f[i][j]=f[i-1][j]
  • 第j個木板空著,此時f[i][j]=f[i][j-1]
  • 第i個人刷[k+1,j]木板,由題意得k+1≤Si≤j并且j-k≤Li,于是存在狀態轉移方程
  • 在dp過程中,我們假定外層變量i為定值,當j增大時,不難發現k的取值范圍上界不變,下界變大。我們不妨比較一下兩個決策k1,k2,假設k1<k2≤Si-1

    因為k2的位置靠后,所以k1最更早的被排除,如果此時滿足

    說明k2不僅更優,而且它存活的時間更長,我們就可以將k1排除。

    因此,我們可以建立一個單調隊列,存儲決策允許集合并且保證決策點k單調遞增,數值f[i-1][k]-Pi*k單調遞減的序列。每次我們取出隊頭決策(最優)進行轉移即可。

    所以,我們就可以設計dp解決問題了

    1 #include <iostream> 2 #include <cstdio> 3 #include <cstring> 4 #include <algorithm> 5 using namespace std; 6 typedef long long ll; 7 inline int read() { 8 int ret=0; 9 int op=1; 10 char c=getchar(); 11 while(c<'0'||c>'9') {if(c=='-') op=-1; c=getchar();} 12 while(c<='9'&&c>='0') ret=ret*10+c-'0',c=getchar(); 13 return ret*op; 14 } 15 struct node { 16 int l,s,p; 17 bool operator <(const node &x) const { 18 return s<x.s; 19 } 20 }a[110]; 21 int n,m,f[110][16010]; 22 int q[16010],l,r; 23 inline int calc(int i,int k) { 24 return f[i-1][k]-a[i].p*k; 25 } 26 int main() { 27 n=read(); m=read(); 28 for(int i=1;i<=m;i++) { 29 a[i].l=read(); 30 a[i].p=read(); 31 a[i].s=read(); 32 } 33 sort(a+1,a+m+1); 34 for(int i=1;i<=m;i++) { 35 l=1,r=0; 36 for(int k=max(0,a[i].s-a[i].l);k<=a[i].s-1;k++) { 37 while(l<=r&&calc(i,k)>=calc(i,q[r])) r--; 38 q[++r]=k; 39 } 40 for(int j=1;j<=n;j++) { 41 f[i][j]=max(f[i-1][j],f[i][j-1]); 42 if(j>=a[i].s) { 43 while(l<=r&&j-a[i].l>q[l]) l++; 44 if(l<=r) f[i][j]=max(f[i][j],calc(i,q[l])+j*a[i].p); 45 } 46 } 47 } 48 printf("%d\n",f[m][n]); 49 return 0; 50 } AC Code

    ?

    轉載于:https://www.cnblogs.com/shl-blog/p/10989144.html

    總結

    以上是生活随笔為你收集整理的【POJ1821】Fence的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    主站蜘蛛池模板: 国产中文字幕乱人伦在线观看 | 日韩影视一区二区三区 | 日韩精品欧美 | 性欧美大战久久久久久久 | 亚洲制服一区二区 | 韩日av在线播放 | 久久狠狠高潮亚洲精品 | 亚洲精品视频在线观看视频 | www激情 | 91视频看| 日本wwwwww| 最近日韩中文字幕中文 | 饥渴的少妇和男按摩师 | 超碰中文字幕在线 | 日韩不卡视频在线观看 | 久草色在线| 伊人久久久 | 色播五月激情五月 | 中文字幕一区二区三区人妻 | 日本成人毛片 | 强开乳罩摸双乳吃奶羞羞www | 亚欧中文字幕 | 国产色黄 | wwwxxx欧美| 动漫美女被吸奶 | 中文国语毛片高清视频 | av中文字幕第一页 | 91人人澡人人爽人人精品 | 特级西西人体444www | 男女免费视频 | 美女日日日 | 国产精品女人久久久 | 婷婷六月在线 | 亚洲免费成人 | 性做久久久久久免费观看欧美 | 手机在线一区二区 | 中文字幕免费高清网站 | 国产精品一区二区三区不卡 | 这里有精品 | 国产又粗又猛又爽又黄的视频小说 | 中文字幕不卡一区 | 幸福宝在线观看 | 午夜寂寞少妇 | 天堂va蜜桃一区二区三区漫画版 | 麻豆精品国产传媒av绿帽社 | 亚洲天堂精品在线观看 | 国产做爰xxxⅹ高潮视频12p | 夜夜艹天天干 | 国产一区二区三区日韩 | 在线你懂得 | 黄色精品视频 | 夜夜春很很躁夜夜躁 | 亚洲精品高清视频在线观看 | 中文在线不卡视频 | 91网站免费看| 岛国片免费在线观看 | 糖心视频在线 | 日韩免费小视频 | 黄色变态网站 | 九九黄色大片 | 色诱视频在线观看 | 黄色大片一级 | 91成年视频 | 精品久久久久久中文字幕 | av片在线观看免费 | 久久网址| 奇米四色在线观看 | 欧美国产综合视频 | 国产精品扒开做爽爽爽的视频 | 福利网址在线观看 | 久久综合一区 | 女性向小h片资源在线观看 日本天天操 | 琪琪色视频 | 国产精品自拍在线观看 | 亚洲精品国产欧美在线观看 | 亚欧激情 | 成人精品一区二区 | xxxxⅹxxxhd日本8hd | 日韩欧美中文在线观看 | 福利小视频在线 | 久久av资源站 | 亚洲无码精品一区二区三区 | 激情婷婷综合 | 成人av免费在线 | 动漫av一区二区三区 | 国产一级二级三级在线 | 国产偷自拍 | 亚洲成人黄色网址 | 国产精品视频www | 日本国产在线 | 亚洲精品国产精品国 | 人av在线 | 国内av| av午夜天堂| 操操影视| 小珊的性放荡羞辱日记 | 日本久久亚洲 | 国产99久久久国产精品免费看 | 欧美熟妇激情一区二区三区 |