Luogu P2577 [ZJOI2005]午餐

一道貪心+類背包DP的好題

首先發現一個十分顯然的性質,沒有這個性質整道題目都難以下手:

無論兩隊的順序如何,總是讓吃飯慢的人先排隊

這是一個很顯然的貪心,因為如果讓吃飯慢的排在后面要更多的時間至少沒有這樣優

因此我們先按吃飯時間從大到小sort一下

然后我們發現這是一個類01背包的DP,只不過這里的狀態要么是01,要么是10(即要么在1隊,要么在2隊)

然后這種東西都有一些很神奇的性質,比如說我們用前綴和sum[i]表示前i個人中排隊的總時間,那么

sum[i]-前i個人中去1號窗口的人的打飯時間之和=前i個人中去1號窗口的人的打飯時間之和

然后我們可以想出一個DP,用f[i][j]表示前i個人中,在1號窗口排隊的人共花了j分鐘排隊的最優情況下,最少要多少時間(要和2號窗口的取一個min),包括吃飯的時間

然后就有轉移:

  • f[i][j]=min(f[i][j],max(f[i-1][j-a[i].t],j+a[i].e))(在1號窗口打飯)

  • f[i][j]=min(f[i][j],max(f[i-1][j],sum[i]-j+a[i].e)(在2號窗口打飯)

然后我們發現這個可以滾動存儲不過也沒這個必要,但是我還是寫了

CODE

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=205;
struct data
{int t,e;
}a[N];
int n,f[2][N*N],sum[N],ans;
inline char tc(void)
{static char fl[100000],*A=fl,*B=fl;return A==B&&(B=(A=fl)+fread(fl,1,100000,stdin),A==B)?EOF:*A++;
}
inline void read(int &x)
{x=0; char ch=tc();while (ch<'0'||ch>'9') ch=tc();while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=tc();
}
inline bool comp(data a,data b)
{return a.e>b.e;
}
inline int min(int a,int b)
{return a<b?a:b;
}
inline int max(int a,int b)
{return a>b?a:b;
}
int main()
{//freopen("CODE.in","r",stdin); freopen("CODE.out","w",stdout);register int i,j;for (read(n),i=1;i<=n;++i)read(a[i].t),read(a[i].e);sort(a+1,a+n+1,comp);for (i=1;i<=n;++i)sum[i]=sum[i-1]+a[i].t;memset(f[0],63,sizeof(f[0])); f[0][0]=0;for (i=1;i<=n;++i){int now=i&1,last=now^1;memset(f[now],63,sizeof(f[now])); ans=f[now][0];for (j=sum[i];j>=0;--j){if (j>=a[i].t) f[now][j]=min(f[now][j],max(f[last][j-a[i].t],j+a[i].e));if (sum[i]-j>=a[i].t) f[now][j]=min(f[now][j],max(f[last][j],sum[i]-j+a[i].e));}}for (i=0;i<=sum[n];++i)ans=min(ans,f[n&1][i]);printf("%d",ans);
}

轉載于:https://www.cnblogs.com/cjjsb/p/9016515.html

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

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

相關文章

SEO【總結】by 2019年5月

2019獨角獸企業重金招聘Python工程師標準>>> 關鍵點&#xff1a; 1、代碼 1.1、seo前端代碼&#xff1a;基于Html代碼的SEOherf&#xff1a;https://my.oschina.net/u/2862573/blog/3030664 注意的要點&#xff1a; h1&#xff0c;h2的內容很關鍵 網頁的壓縮、靜態化…

Linux 系統的啟動順序

第一步&#xff1a;加載BIOS當你打開ia計算機的電源&#xff0c;計算機會首先加載計算機主板的BIOS信息&#xff0c;因為它包含了CPU的相關信息&#xff0c;設備啟動順序[安裝系統的U盤啟動順序]&#xff0c;內存信息&#xff0c;時鐘信息&#xff0c;PnP特性等等&#xff0c; …

Oracle數據庫 查看表是否是 索引組織表的方法

1. 最近在工作過程中發現 一個表插入很慢 以為是索引組織表, 所以一直有點糾結 但是發現 產品里面是沒有IOT的 于是找了下公司的OCP 問了下 如何查看 就是 user_tables 視圖里面的一個字段. 見圖: 轉載于:https://www.cnblogs.com/jinanxiaolaohu/p/9018037.html

Windows server 2016 搭建RDS服務

計算機的更新換代太快&#xff0c;新購置的計算機沒幾年便覺得運行速度越來越慢&#xff0c;尤其是在運行一些比較大的應用程序是&#xff0c;用戶總是抱怨運行速度太慢或者總是死機等問題。如果要更換新的計算機&#xff0c;又得不到領導的批準&#xff0c;因此對于企業來說&a…

π 的定義(極限)

圓周率&#xff0c;周長&#xff08;2πr&#xff09;與直徑&#xff08;2r&#xff09;的比值。在名稱上&#xff0c;是通過計算命名的。 1. 劉徽割圓與圓周率 π 通過圓內接正多邊形的周長來計算圓周長&#xff0c;是三世紀中期我國魏晉時代的數學家劉徽的光輝思想。 對于圓內…

前端開發瀏覽器兼容問題

csshack 1234567我很少使用hacker的&#xff0c;可能是個人習慣吧&#xff0c;我不喜歡寫的代碼IE不兼容&#xff0c;然后用hack來解決。不過hacker還是非常好用的。使用hacker我可以把瀏覽器分為3類&#xff1a;IE6 &#xff1b;IE7和遨游&#xff1b;其他&#xff08;IE8 chr…

springboot2.0 多數據源整合問題 At least one JPA metamodel must be present! ??at

2019獨角獸企業重金招聘Python工程師標準>>> 數據源代碼&#xff1a; 第一個讀取配置文件代碼&#xff1a; package com.datasource;import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.sp…

好書推薦

阿爾花剌子模:代數學. 喬治波利亞:怎樣解題:數學思維的新方法. Anany Levitin:算法設計與分析基礎.轉載于:https://www.cnblogs.com/mtl6906/p/7625290.html

docker實戰系列之搭建rabbitmq

1.搜索鏡像【注&#xff1a;因為我這里采用的是阿里云鏡像加速器,所以我直接在阿里云中搜索相關鏡像路徑】,點擊"詳情"查看公網拉取路徑 2.拉取鏡像 docker pull registry.cn-hangzhou.aliyuncs.com/jc/rabbitmq-3 3.查看拉取的鏡像 docker images 4.創建并運行容器【…

【hdu 6038】Function

【Link】:http://codeforces.com/contest/834/problem/C 【Description】 給你兩個排列a和b; a排列的長度為n,b排列的長度為m; a∈[0..n-1],b∈[0..m-1]; 然后讓你求一個函數f[i]; f[i]的定義域為0..n-1,值域為0..m-1 同時使得對于任意f[i],i∈[0..n-1]; f(i)bf(a[i])成…

樹中點對距離(點分治)

題目 給出一棵帶邊權的樹&#xff0c;問有多少對點的距離<Len 分析 這是一道點分治的經典題目&#xff0c;可以給點分治的初學者練手。 點分治&#xff0c;顧名思義就是把每個點分開了處理答案。 假設&#xff0c;目前做到了以x為根的子樹。 先求出子樹中每個點到根的距離\(…

【a702】貸款利率

Time Limit: 10 second Memory Limit: 2 MB 問題描述 當一個人從銀行貸款后&#xff0c;在一段時間內他將不得不每月嘗還固定的分期付款。這個問題要求計算機出貸款者向銀行支付的利率。假設利率按月累計。 Input 輸入文件 僅一行包含三個用空格隔開的正整數。 第一個整數表示…

移動端適配--meta標簽玩的是什么

基本一直都在做移動端的開發&#xff0c;rem布局也寫了很久&#xff0c;不過對于實現的原理有些模棱兩可的盲點&#xff0c;自己總結一下留著以后回顧。 本文分以下幾個層面&#xff0c;主打用最最通俗的語言來闡述。 布局小例子viewport作用viewport和移動端適配的關系flexibl…

python-json

demjson.encode(self, obj, nest_level0) &#xff1a;用于將 Python 對象編碼成 JSON 字符串。 #!/usr/bin/python import demjsondata [ { a : 1, b : 2, c : 3, d : 4, e : 5 } ]json demjson.encode(data) print json demjson.decode(self, txt) &#xff1a;解碼 JSON 數…

計算機基礎知識--編碼知識

編碼回顧 編碼轉換 Python的bytes類型 編碼回顧 在備編碼相關的課件時&#xff0c;在知乎上看到一段關于Python編碼的回答 這哥們的這段話說的太對了&#xff0c;搞Python不把編碼徹底搞明白&#xff0c;總有一天它會猝不及防坑你一把。 不過感覺這哥們的答案并沒把編碼問題寫明…

Linux——安裝FTP服務器

1、檢查安裝vsftpd軟件 使用如下命令#rpm -qa |grep vsftpd可以檢測出是否安裝了vsftpd軟件&#xff0c; 如果沒有安裝&#xff0c;使用YUM命令進行安裝。 2、啟動服務 使用vsftpd軟件&#xff0c;主要包括如下幾個命令&#xff1a; 啟動ftp命令#service vsftpd start 停止ftp…

測試開發面試準備之Selenium 工作原理

Selenium 經歷了兩個版本&#xff0c;Selenium 1.0 和 Selenium 2.0&#xff0c;本文僅介紹Selenium2的原理&#xff0c;在Selenium 2.0 主推的是WebDriver,Selenium2又名Selenium Webdriver。 Selenium2簡介 Selenium是一個用于Web應用程序測試的工具&#xff0c;支持多平臺、…

CodeForces 11D(狀壓DP 求圖中環的個數)

Given a simple graph, output the number of simple cycles in it. A simple cycle is a cycle with no repeated vertices or edges. Input The first line of input contains two integers n and m (1?≤?n?≤?19, 0?≤?m) – respectively the number of vertices an…

vue插槽的使用(slot)

插槽 該頁面假設你已經閱讀過了組件基礎。如果你還對組件不太了解&#xff0c;推薦你先閱讀它。 插槽內容 Vue 實現了一套內容分發的 API&#xff0c;這套 API 基于當前的 Web Components 規范草案&#xff0c;將 <slot> 元素作為承載分發內容的出口。 它允許你像這樣合成…

圖片與二進制流轉換

#region//圖片轉換為二進制流 public void PictureToBinaryStream() { //獲取當前程序運行路徑 string path Application.StartupPath; //拼接成測試圖片路徑 string fullPath path "\\images\\test.png"; //初始化類 Bitmap bmp…