BZOJ4426 : [Nwerc2015]Better Productivity最大生產率

如果一個區間包含另一個區間,那么這兩個區間是否在一起的生產率是一樣的。

將所有這種包含了其他區間的區間放入數組$b$,其余的放入數組$c$,有多個相同的時候則從$b$移一個到$c$。

那么$c$里所有區間左端點遞增,右端點也遞增,設$f[i][j]$為$c$中前$j$個區間劃分成$i$組的最大收益,直接DP即可,決策具有單調性。

然后把$p$分配給$b$和$c$,求出$b$和$c$組合取來的最大收益即可。

時間復雜度$O(n^2\log n)$。

?

#include<cstdio>
#include<algorithm>
#define N 210
using namespace std;
int n,m,i,j,flag,cb,cc,s[N],f[N][N],ans=-2147400000;
struct P{int x,y;}a[N],b[N],c[N];
bool cmpb(P a,P b){return a.y-a.x>b.y-b.x;}
bool cmpc(P a,P b){return a.x<b.x;}
void dp(int p,int l,int r,int dl,int dr){int m=(l+r)>>1,dm=dl,t=ans;for(int i=min(m-1,dr);i>=dl;i--){if(c[i+1].y<=c[m].x)break;int now=f[p-1][i]+c[i+1].y-c[m].x;if(now>=t)t=now,dm=i;}f[p][m]=t;if(l<m)dp(p,l,m-1,dl,dm);if(r>m)dp(p,m+1,r,dm,dr);
}
int main(){scanf("%d%d",&n,&m);for(i=1;i<=n;i++)scanf("%d%d",&a[i].x,&a[i].y);for(i=1;i<=n;i++){for(flag=0,j=1;j<=n;j++)if(a[i].x<=a[j].x&&a[j].y<=a[i].y&&(a[i].x!=a[j].x||a[i].y!=a[j].y||i<j)){flag=1;break;}if(flag)b[++cb]=a[i];else c[++cc]=a[i];}sort(b+1,b+cb+1,cmpb);for(i=1;i<=cb;i++)s[i]=s[i-1]+b[i].y-b[i].x;sort(c+1,c+cc+1,cmpc);for(i=1;i<=cc;i++)f[0][i]=ans;for(i=1;i<=m;i++)f[i][0]=ans;for(i=1;i<=m;i++)dp(i,1,cc,0,cc);for(i=1;i<=m;i++)if(m-i<=cb&&f[i][cc]>=0)ans=max(ans,f[i][cc]+s[m-i]);return printf("%d",ans),0;
}

  

轉載于:https://www.cnblogs.com/clrs97/p/5292903.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/255758.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/255758.shtml
英文地址,請注明出處:http://en.pswp.cn/news/255758.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[codevs1105][COJ0183][NOIP2005]過河

[codevs1105][COJ0183][NOIP2005]過河 試題描述 在河上有一座獨木橋&#xff0c;一只青蛙想沿著獨木橋從河的一側跳到另一側。在橋上有一些石子&#xff0c;青蛙很討厭踩在這些石子上。由于橋的長度和青蛙一次跳過的距離都是正整數&#xff0c;我們可以把獨木橋上青蛙可能到達的…

ABB機器人套接口通信 機器人部分

ABB機器人套接口通信 機器人部分 文章機器人部分&#xff0c;描述如何運行機器人從機程序&#xff0c;使機器人根據上位機節點發送的命令&#xff0c;執行具體運動。 ABB機器人執行3個任務。這些任務都配置為SEMISTATIC(背景程序)的任務,第三任務是正常動作任務。下文描述如…

CRM項目總結

CRM項目總結 一&#xff1a;開發背景 在公司日益擴大的過程中&#xff0c;不可避免的會伴隨著更多問題出現。 對外 &#xff1a; 如何更好的管理客戶與公司的關系&#xff1f;如何更及時的了解客戶日益發展的需求變化&#xff1f;公司的產品是否真的符合客戶需求&#xff1f;以…

【面經——《速騰聚創科技有限公司——深度學習算法工程師》】

自我介紹 實習項目 1&#xff09;項目主要應用的領域&#xff1f; 2&#xff09;難點在哪&#xff1f;——機械臂吸盤大小和目標大小之間坐標的協調 3&#xff09;難點不在于算法&#xff0c;在于數據的處理和均衡性&#xff1f;對于數據均衡方面有什么理解&#xf…

js變量和數據類型

轉載于:https://www.cnblogs.com/songyinan/p/6181421.html

offline .net3.5

1.加載虛擬光驅 2.dism.exe /online /enable-feature /featurename:netfx3 /Source:D:\sources\sxs轉載于:https://www.cnblogs.com/BillLei/p/5294082.html

(九)模板方法模式詳解(包含與類加載器不得不說的故事)

作者&#xff1a;zuoxiaolong8810&#xff08;左瀟龍&#xff09;&#xff0c;轉載請注明出處&#xff0c;特別說明&#xff1a;本博文來自博主原博客&#xff0c;為保證新博客中博文的完整性&#xff0c;特復制到此留存&#xff0c;如需轉載請注明新博客地址即可。 模板方法模…

阿里云openapi接口使用,PHP,視頻直播

1.下載sdk放入項目文件夾中 核心就是aliyun-php-sdk-core&#xff0c;它的配置文件會自動加載相應的類 2.引入文件 include_once LIB_PATH . ORG/aliyun-openapi/aliyun-php-sdk-core/Config.php; 3.配置客戶端對象,需要Access Key ID,Access Key Secret $iClientProfile Defa…

【面經——《廣州敏視數碼科技有限公司》——圖像處理算法工程師-深度學習方向】

目錄 筆試 HR面 專業面——60多分鐘 主管面 反問&#xff1a; 筆試 8道題——簡答題 1道編程 蘋果、香蕉、梨、菠蘿&#xff0c;彩色圖像如何進行分類&#xff1f;一輛帶車牌的汽車&#xff0c;圖像亮度整體呈現偏亮狀態&#xff0c;如何…

Android之網絡編程利用PHP操作MySql插入數據(四)

因為最近在更新我的項目&#xff0c;就想著把自己在項目中用到的一些的簡單的與網絡交互的方法總結一下&#xff0c;所以最近Android網絡編程方面的博文會比較多一些&#xff0c;我盡量以最簡單的方法給大家分享&#xff0c;讓大家明白易懂。如果有什么不對的地方&#xff0c;還…

RAPID 信號的互鎖和同步 WaitTestAndSet 和 TestAndSet

RAPID 信號的互鎖和同步 WaitTestAndSet 指令等待指定的持久型 BOOL 變量變成 FALSE.當變量值變為 FALSE, 該指令將設置變量為 TRUE 并繼續執行. 該持久型變量可被作為同步或者互斥時的一個 BOOL 信號量。 這個指令與 TestAndSet 有著同樣的基本功能。但是 WaitTestAnd…

【常用網址】——opencv等

opencv官網Releases - OpenCVhttps://opencv.org/releases/

(五):C++分布式實時應用框架——微服務架構的演進

C分布式實時應用框架——微服務架構的演進 技術交流合作QQ群&#xff1a;436466587 歡迎討論交流 上一篇&#xff1a;(四)&#xff1a;C分布式實時應用框架——狀態中心模塊 版權聲明:本文版權及所用技術歸屬smartguys團隊所有&#xff0c;對于抄襲&#xff0c;非經同意轉載等…

如何通過軟件項目開發來提高自身的實力。

在我們這個專業&#xff0c;大多數人都不會將軟件開發當作自己的事業&#xff0c;因為若要在這個行業上能夠立足&#xff0c;得需要一個好的基礎&#xff0c;但是由于這個東西并不是可以通過書本能夠徹底的理解和 掌握的&#xff0c;隨著時間的變化&#xff0c;我們身邊的科技也…

夢回JavaScript--數據類型之undefined

undefined類型只有一個值&#xff0c;即undefined。在使用var聲明變量但未對其加以初始化時&#xff0c;這個變量的值就是undefined&#xff1b; var mes; alert(mes undefined) //true如果變量沒有聲明就會出現錯誤 var mes; alert(mes) //undefined alert(a)//error 然而有一…

Robot Application Builder

軟件開發工具包 Robot Application Builder是安裝在PC機&#xff08;Windows 2000或Windows XP操作系統&#xff09;上的一種獨立開發工具&#xff0c;可用于創建運行于ABB FlexPendant示教器或PC機上的定制化操作界面。為此&#xff0c;該軟件包由以下兩部分組成&#xff1a;…

asp.net model 驗證和取出 ErrorMessage 信息

為什么80%的碼農都做不了架構師&#xff1f;>>> public class Users{public int Id { get; set; }public string Name { get; set; }[Required(ErrorMessage "郵箱不能為空")][EmailAddressAttribute(ErrorMessage "郵箱格式不正確")]public…

this

作者&#xff1a;李挺鏈接&#xff1a;https://www.zhihu.com/question/19636194/answer/123274198來源&#xff1a;知乎著作權歸作者所有&#xff0c;轉載請聯系作者獲得授權。關于 this 的描述&#xff0c;曾經在 stackoverflow 上看到了一篇回答寫的非常詳盡&#xff0c;下面…

DeviceNet 消息類型

DeviceNet是一種低成本的通訊總線鏈接&#xff0c;具有開放現場網絡標準&#xff0c;規范和協議都是開放的。DeviceNet將控制和數據融合在一起&#xff0c;信息具有數據標識區&#xff0c;網絡利用標識區進行優先級仲裁&#xff0c;可以高效傳送I/O數據。 DeviceNet有兩種不同類…