题目描述

经过多年的杀戮,秦皇终于统一了中国。为了抵御外来的侵略,他准备在国土边境安置n名将军。不幸的是这n名将军羽翼渐丰,开始展露他们的狼子野心了。他们拒绝述职、拒绝接受皇帝的圣旨。

秦皇已经准备好了秘密处决这些无礼的边防大将。

不过为防兵变,他决定先授予这些将军一些勋章,为自己赢得战略时间。将军们听说他们即将被授予勋章都很开心,他们纷纷上书表示感谢。第i个将军要求得到ai枚不同颜色的勋章。但是这些将军都很傲气,如果两个相邻的将军拥有颜色相同的勋章他们就会认为皇帝不尊重他们,会立即造反(编号为i的将军和编号为i+1的将军相邻;因为他们驻扎的边境可以类似看成一个圆形,所以编号1和编号n的将军也相邻)。

皇帝不得不满足每个将军的要求,但对他们的飞扬跋扈感到很气愤。于是皇帝决定铸造尽量少种类的勋章来满足这些狂妄者的要求。请问他至少要铸造多少种颜色的勋章?

输入格式

第一行有一个整数n(1<=n<=20000)。

接下来n行每行一个整数ai,表示第i个将军要求得到多少种勋章。(1<=ai<=100000)

输出格式

输出一个整数,即最少需要多少种勋章。

输入输出样例

输入 #1复制

4
2 2 1 1
输出 #1复制
    4

一句话题意:

  • 有N个将军,每人想要一定量的勋章,他们排成一个环,每个人和他相邻的两个人有的勋章都不能一样,问总共要造多少个勋章

考试时没时间时骗分的方法

  • 这题第一眼会产生两种方法:一个事二分加乱搞,另一个就是贪心+撞运气,在完全没有思路或者没时间的时候第二种方法加一个对拍就是一个好的方法;
  • 这题感觉考试时不少人都在贪,廖半仙和ZWJDD不知道咋搞的炸了,可为啥我的贪心没有脑子,还有55分???
  • 感觉凭感觉会觉得答案就是A[i]+A[i+1]的最大值,至于为什么证明后面会有。
  • 然后交上去,也确实啥也没判,也没分奇偶,还有分,还怪多。。。

考试时在时间很多/第三题一点也不会时(就像这次)搞的正解

  • 正解感觉也很神奇,对于考试时是怎么想到的,我也不知道,感觉什么都不能用,那就DP吧。。。
  • 先举几个栗子:

                   

样例:巨水,偶数个,很简单可得有四个                              5个人,没人都要一个,可得要三个                     三个人,每人要一个,共要3个

  • 一个大胆的想法偶数时,很简单,自己和相邻的一个人取一个最大值,因为是偶数个,可以将奇数分为一组,偶数分为一组,让他们没有勋章是一样的,很容易可以想到。
  • 在看后面两个奇数时,发现没有什么明显的规律,那就很明显的发现,这题难就难在奇数,任何奇数都可以拆成2*N+1的形式,那最后的那个1怎么办?

奇数时判断的方法(重点):

  • 重点就在于怎么判断最后一个和第一个(废话。。。)
  • 这题贪心果断排除,什么其他高级算法也想不到,那就写DP吧。。。感觉除了长得清奇一点还是很好想的。
  • maxn【i】:表示在前(i-1)个均不冲突时,第i个点与第1个点冲突的最大值
  • mx【i】:表示在前(i-1)个均不冲突时,第i个点与第1个点冲突的最小值
  • 方程式1:maxn【i】=min ( a [ i ]  , a [ 1 ]  -  mx [  i-1  ]  )
  • 解释:要使  i  和  1  的冲突最大,而且还不能让  i  和  i-1  的冲突太大,那就表明  i-1  和  1  的冲突要尽可能的小,而  A[1]  中除去   mx[i-1]   之后,剩下的所有元素都合适,故得证。
  • 方程式2:mx[  i  ]=max (  0  ,   a  [  i  ]  --  (  x  -  a  [  i  -  1  ]  -  a  [  1  ]  +  maxn  [  i-1  ]));
  • 解释:要想使冲突最小,那就意味着除去不得不冲突的,其他一定不冲突。。。设总共有X种不同的勋章(这个事二分出来的) ,a  [  i  ]  --  (  x  -  a  [  i  -  1  ]  -  a  [  1  ]  +  maxn  [  i-1  ]  )表示在X种中除去必须和  1  还有  i-1  冲突的,由于可能有重复,所以还要加上maxn  [  i-1  ]  (此时可令  1 和  i-1的冲突很大,这样可以保证剩下来的最多。)如果剩下的额不足 A[ i ]  则表示一定会冲突。
  • 判断:最后判断一下mx【N】是否为0,如果为0就意味着当前的X是成立的。
  • 最后就是代码
  • 对于为什么二分要从最大值开始,是因为MX和MAXN都是在满足与前面不冲突的情况下设立的,可以这样理解,任意一个奇数都可以拆成一个偶数+1,我们必须在满足那个偶数的情况下去处理奇数,也就意味着答案一定比那个偶数成立的还要大,一旦比他小,偶数前面的偶数就已经不满足了,也就一定不会满足这个奇数

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath> using namespace std; const int maxn1=; int n,m,a[maxn1],sum,maxn[maxn1],mx[maxn1];
bool pd(int x)
{
maxn[]=mx[]=a[];
for (int i=;i<=n;i++)
{
maxn[i]=min(a[]-mx[i-],a[i]);
mx[i]=max(,a[i]-(x-a[i-]-a[]+maxn[i-]));
}
if (!mx[n])
{
return true;
}
else
{
return false;
}
}
int main()
{
ios::sync_with_stdio(false);
cin>>n;
for (int i=;i<=n;i++)
{
cin>>a[i];
sum+=a[i];
}
int l=a[]+a[];
int r=sum;
int ans=sum;
for (int i=;i<=n-;i++)
{
l=max(l,a[i]+a[i+]);
}
l=max(l,a[]+a[n]);
while(l<=r)
{
int mid=(l+r)>>;
if (pd(mid))
{
ans=min(ans,mid);
r=mid-;
}
else
{
l=mid+;
}
}
cout<<ans<<endl;
}

最后的最后这题有一个什么乱搞的方法,可以去这位大佬的博客里看看(传送门

反正这句话我看的是真的爽。。。

最后日常水一下,BK201果然还是太神了。。。ZWJdd果然还是太巨了。。。SHYMM还是太牛了。。。。阿基米德的的那啥盆还是太神奇了。。。。。

最后还有其他没水到的大佬,如果有下次讲题的机会一定水到。

NOIP模拟赛18 皇帝的烦恼O(∩_∩)O 二分+DP的更多相关文章

  1. 【noip模拟赛6】收入计划 最大值的最小值 二分答案

    描述 高考结束后,同学们大都找到了一份临时工作,渴望挣得一些零用钱.从今天起,Matrix67将连续工作N天(1<=N<=100 000).每一天末他可以领取当天及前面若干天里没有领取的工 ...

  2. 【2019.7.20 NOIP模拟赛 T2】B(B)(数位DP)

    数位\(DP\) 首先考虑二进制数\(G(i)\)的一些性质: \(G(i)\)不可能有连续两位第\(x\)位和第\(x+1\)位都是\(1\).因为这样就可以进位到第\(x+2\)位.其余情况下,这 ...

  3. CH Round #48 - Streaming #3 (NOIP模拟赛Day1)

    A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ...

  4. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  5. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  6. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  7. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  8. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  9. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

随机推荐

  1. Java后端工程师必备书单(从Java基础到分布式)

    Java开发工程师一般负责后端开发,当然也有专门做Java Web的工程师,但是随着前后端的分离,越来越多的Java工程师需要往大后端方向发展. 今天我们就来介绍一下Java后端开发者的书单. 首先要 ...

  2. Unity动态改变物体遮挡关系

    在动态创建物体时,通常同父级下先创建的子物体会被后创建的遮挡,此时就需要我们用代码改变对象的层级. GameObject go;go.transform.SetAsLastSibling();//设置 ...

  3. bugku 成绩单

    看起来像是SQL注入,先来试试. 输入1,2,3显示的是三个人成绩. 来试试是否存在注入. 输入1,正常.输入1' 错误.输入1’#正常,说明存在注入点. 首先来看下有几列从1开始试,1’ order ...

  4. 最新打赏正版V15微信视频打赏源码 带(百倍)暗雷 N秒试看 自动切换域名 自动防封

    免签支付域名防封随机跳转盒子推广设置试看N秒百倍 平台搭建:乌龟-源码科技QQ:64430146 全新版本 V15打赏版本功能介绍: 特别注意: 新增加功能!!!! 1.包括V14所有功能(除个别因优 ...

  5. Vue的介绍及安装和导入

    08.27自我总结 Vue的介绍及安装和导入 本质就是封装一些js 一Vue的介绍 进式 JavaScript 框架 通过对框架的了解与运用程度,来决定其在整个项目中的应用范围,最终可以独立以框架方式 ...

  6. 如何正确的在 Android 上使用协程 ?

    前言 你还记得是哪一年的 Google IO 正式宣布 Kotlin 成为 Android 一级开发语言吗?是 Google IO 2017 .如今两年时间过去了,站在一名 Android 开发者的角 ...

  7. Python_散点图绘制

    为了可视化一些数据分布,需要以散点图的形式呈现 引入绘图工具 import matplotlib.pyplot as plt from matplotlib.font_manager import F ...

  8. 机器学习:LibSVM与weka在eclipse中的使用

    LibSVM是weka3.5以后的版本新加的功能,使用这个算法必须自己下载jar包,配置进项目: LibSVM在weka可视化界面的使用,很多人写过,但在clipse下的调用资料却不多,试了很多都不能 ...

  9. HTML DIV充满整个屏幕

    <!DOCTYPE html> <html> <head> <title>A Little Game!</title> <meta c ...

  10. 生成函数(TBC)

    生成函数 生成函数 (Generating Function) 的应用简单来说在于研究未知(通项)数列规律,用这种方法在给出递推式的情况下求出数列的通项. 对于一个数列 aaa,称f(x)=∑i=0n ...