二分答案(by jie)

目录

1.前言:

2.方法:

3.典型例题

例题1.奇怪的函数(裸二分答案)

例题2.关押罪犯(二分答案+染色)

例题3.电话网络(二分答案+最短路径)

例题4.software(二分答案+DP)

4.结语:

--------------------------------

1.       前言:

二分答案顾名思义就是二分出答案来验证

通俗一点来说就是在[1,∞]上

每次取中间点,猜答案..

把答案作为已知条件

判断答案是否满足题意..

从而求证出所需解的过程

2.       方法:

var

l,r,m:longint;

ans:longint;

begin

l:=1; r:=n;

ans:=0;

while l<=r do

begin

m:=(l+r) shr 1;

if pd(m) then begin ans:=m; r:=m-1; end

else l:=m+1

end;

writeln(ans);

end;

3.       典型例题

例题1奇怪的函数

问题描述

使得xx达到或超过n位数字的最小正整数x是多少?

输入数据
    输入一个正整数n。

输出数据
    输出使得xx达到n位数字的最小正整数x。

输入样例
11

输出样例
10

时间限制
    各测试点1秒

内存限制
    你的程序将被分配32MB的运行空间

数据规模
    n<=2 000 000 000

-----------------------------------------------------------------------------------------------------------------

问题分析:

1.首先要知道换底公式来求位数:

位数=ln(xx)/ln(10)+1

=x*(ln(x)/ln(10))

2.确定二分方案:

l:=1; r:=max;

while l<=r do

begin

mid:=(l+r) shr 1;

if js(mid)>=n then

begin

ans:=mid;

r:=mid-1;

end

else

l:=mid+1;

end;

writeln(ans);

3.小结:

最基础的二分题只用知道换底公式来求位数就可以做出来了

代码:ctrl+鼠标左键点标题奇怪的函数

===================================================================

例题2:关押罪犯

题目描述

S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N。他们之间的关系自然也极不和谐。很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突。我们用“怨气值”(一个正整数值)来表示某两名罪犯之间的仇恨程度,怨气值越大,则这两名罪犯之间的积怨越多。如果两名怨气值为c 的罪犯被关押在同一监狱,他们俩之间会发生摩擦,并造成影响力为c 的冲突事件。

每年年末,警察局会将本年内监狱中的所有冲突事件按影响力从大到小排成一个列表,然后上报到S 城Z 市长那里。公务繁忙的Z 市长只会去看列表中的第一个事件的影响力,如果影响很坏,他就会考虑撤换警察局长。

在详细考察了N 名罪犯间的矛盾关系后,警察局长觉得压力巨大。他准备将罪犯们在两座监狱内重新分配,以求产生的冲突事件影响力都较小,从而保住自己的乌纱帽。假设只要处于同一监狱内的某两个罪犯间有仇恨,那么他们一定会在每年的某个时候发生摩擦。那么,应如何分配罪犯,才能使Z 市长看到的那个冲突事件的影响力最小?这个最小值是多少?

【输入输出样例说明】

罪犯之间的怨气值如下面左图所示,右图所示为罪犯的分配方法,市长看到的冲突事件影响力是3512(由2 号和3 号罪犯引发)。其他任何分法都不会比这个分法更优。

【数据范围】
  
对于30%的数据有N≤ 15。
   对于70%的数据有N≤ 2000,M≤ 50000。
   对于100%的数据有N≤ 20000,M≤ 100000。

输入格式

输入文件的每行中两个数之间用一个空格隔开。
第一行为两个正整数N 和M,分别表示罪犯的数目以及存在仇恨的罪犯对数。

接下来的M 行每行为三个正整数aj,bj,cj,表示aj 号和bj 号罪犯之间存在仇恨,其怨气值为cj。数据保证1<aj=<=bj<=N ,0 < cj≤ 1,000,000,000,且每对罪犯组合只出现一次。

输出格式

共1 行,为Z 市长看到的那个冲突事件的影响力。如果本年内监狱中未发生任何冲突事件,请输出0。

样例输入

4 6

1 4 2534

2 3 3512

1 2 28351

1 3 6618

2 4 1805

3 4 12884

样例输出

3512

-----------------------------------------------------------------------------------------------------------------

问题分析:

1.属于最大值最小问题:

最大值最小问题一般来说都是二分答案求值

是这样看的

求所有怨气中的最大值的最小值;

2.具体实现:

二分+染色

先二分出一个怨气值,将怨气值作为已知条件

来验证答案是否正确从而求解的过程;

3.小结:

一般二分都不会单独拿出来考,否则就显得太菜了

它往往结合着染色,最短路,DP等等来考

这道就是二分加染色

代码:ctrl+鼠标左键点标题NOIP2010关押罪犯

==================================================================

例题3:电话网络(phone)

【题目描述】

绿化工程终于完成,整个园区生机勃勃。但是,很不幸的是,在绿化过程中,工人们和进出的车辆将铺设好的电话线全部破坏了。Neyc的领导很生气,问题很严重。为了保住面子,工程队负责人,希望尽快恢复园区的电信,他把这个任务交给了你。

已知,园区周围分布N(1<=n<=1000)根按1…n排列的电话线杆,电话线杆之间可以拉电话线。第i对电话线杆的两个端点分别为Ai,Ri,它们间的距离为Li(1<=li<=1000000)。数据中保证每对最多只出现一次。编号为1的电话线杆已经接入了全国的电话网络,整个园区的电话线全部连到了编号为N的电话线杆上。也就是说,你的任务仅仅是找一条将1号和N号电话线杆连起来的路径,其余的电话线杆并不一定要连入电话网络。

绿化工程的负责人与电信公司协商后,电信公司决定免费为园区连接K(0<=k<n)对由你指定的电话线杆。对于此外的那些电话线,就必需为它们付费,总费用等于其中最长的电话线长度(每根电话线仅连接一对电话线杆),其它长度不付费。如果需要连接的电话线杆不超过K对,那么总支出为0。

现在,你就要设计一个费用最少的方案。最后,计算出将电话线引到园区最少需要花多少钱?

【输入格式】

输入文件的第一行包含三个用空格隔开的整数:N ,P和K。

第二行到第P+1行:每行分别都为三个用空格隔开的整数:Ai Bi和Li。

【输出格式】

输出文件仅包含一个整数,表示在这项工程上的最小支出。如果任务不可能完成,则输出-1。

【样例输入】

5 7 1

1 2 5

3 1 4

2 4 8

3 2 3

5 2 9

3 4 7

4 5 6

【样例输出】

4

-----------------------------------------------------------------------------------------------------------------

问题分析

1.属于求最大值最小的问题:

例题2相同,二分答案验证答案

是这样看的

求所有长度中的最大值的最小值

2.具体实现:

二分+最短路径

根据题意就是求1~n的最短距离

超过二分出的答案则dist[j]:=min(dist[i]+1,dist[j])

判断if dist[n]-k>0 then exit(false)

else exit(true);

3.小结:

属于二分+最短路的问题

再次强调:

将二分出的答案当做已知量,判断是否可行

代码:ctrl+鼠标左键点标题电话网络(phone)

===================================================================

例题4:SOFTWARE

【题目描述】

一个软件开发公司同时要开发两个软件,并且要同时交付给用户,现在公司为了尽快完成这一任务,将每个软件划分成m个模块,由公司里的技术人员分工完成,每个技术人员完成同一软件的不同模块的所用的天数是相同的,并且是已知的,但完成不同软件的一个模块的时间是不同的,每个技术人员在同一时刻只能做一个模块,一个模块只能由一个人独立完成而不能由多人协同完成。一个技术人员在整个开发期内完成一个模块以后可以接着做任一软件的任一模块。写一个程序,求出公司最早能在什么时候交付软件。

【输入】

输入文件第一行包含两个由空格隔开的整数n和m,其中1≤n≤100,1≤m≤100。接下来的n行每行包畲两个用空格隔开的整数d1和d2,d1表示该技术人员完成第一个软件中的一个模块所需的天数,d2表示该技术人员完成第二个软件中的一个模块所需的天数,其中l≤d1,d2≤100。

【输出】

输出文件仅有一行包含一个整数d,表示公司最早能于d天后交付软件。

【样例】

SOFTWARE.IN

3   20

1   1

2   4

1   6

SOFTWARE.OUT

18

【样例解释】

最快的方案是第一个技术人员完成第二个软件的18个模块,用时18天,第三个技术人员完成第一个软件的18个模块,用时18天,其余的模块由第二个技术人员完成,用时12天,做完所有模块需要18天。如果第一个技术人员完成第二个软件的17个模块,第三个技术人员完成第一个软件的17个模块,其余的模块由第二个技术人员完成,需要用时18天,做完所有模块仍然需要18天,所以少于18天不可能做完所有模块。

-----------------------------------------------------------------------------------------------------------------

题目分析:

1.属于求最大值最小问题:

是这样看的

我们要求的是两个工作完成的最大天数(两个中的最大天数)的最小值

2.具体实现:

二分答案过后,出来个天数

根据这个天数设计DP方程

DP方程

f[i,j]含义:表示前i个人做j个软件1的模块最多能做多少个软件2的模块

转移:f[i,j]:=max(f[i-1,k]+(ans-(j-k)*peo[i].d1) div peo[i].d2)

if f[n,m]>=m then exit(true)

else exit(false);

3.小结:

当二分遇见了动规后对于我个人现在而言来就算比较难了

困难处:

不怎么容易想到如何通过二分出的答案来验证二分答案的最优性

本题的验证方法比较巧妙

以天数为中转条件

算出软件2在软件1做m个时软件2是否能做m个为判断条件

代码:ctrl+鼠标左键点标题SOFTWARE

4.       结语:

1.总的来说二分答案并不是个困难的内容

2.主要注意的是

1.一般的题目命题点:求最大值最小问题。

2.对二分出的答案进行转换,验证是一个难点。

3.不着么可能会单独出题,一般来说会和染色,最短路,DP等结合起来。

3.本难度属于NOIP内容,希望各位ACM/NOI/省队神牛看到后不要嘲笑我这弱菜

4.转载请标明出处http://blog.csdn.net/jie_guale(by jie于2011-10-14晚总结)

二分答案(by jie)相关推荐

  1. UVA1396 Most Distant Point from the Sea(AM - ICPC - Tokyo - 2007)(计算几何,半平面交 + 二分答案)

    整理的算法模板合集: ACM模板 题目传送门 见<训练指南>P279 很明显就是一个二分答案,它问的是最远的点,直接枚举因为这里都是double类型的数所以有无限个点,我们可以直接二分. ...

  2. UVA1146 / LA3211(ACM-ICPC 2004 Europe - Southwestern) Now or later(2-SAT问题 + 二分答案)

    题目要求为 最大化最小值,很明显就是二分答案. 题目中每个飞机 要么是一种状态(早),要么是另一种状态(晚),考虑 2-SAT. 我们二分答案,二分着陆时间间隔的最小值 x. 枚举每两个飞机 p , ...

  3. 解题报告:luoguP2868 Sightseeing Cows G(最优比率环,负环判定,二分答案)

    根据题意,我们要环上各点权值之和除以各边权值之和最大. 求最大答案,很明显可以使用二分答案.那么我们假设当前答案为 x,如果有更大的答案,那么方程就可以按下图转换: 也就是说如果有更大的答案,则有一个 ...

  4. P2759 奇怪的函数(二分答案,数学运算)

    P2759 奇怪的函数 范围2e92e92e9,直接枚举肯定超时,正着直接求答案求不出来,那么运用逆向思维,直接二分答案判断即可.这道题涉及简单的数学运算. 要xx>=nx^x>=nxx& ...

  5. P3743 kotori的设备(二分答案,思维,线性)难度⭐⭐⭐

    题目链接 题目背景 kotori 有 n 个可同时使用的设备. 题目描述 第 i 个设备每秒消耗ai个单位能量.能量的使用是连续的,也就是说能量不是某时刻突然消耗的,而是匀速消耗.也就是说,对于任意实 ...

  6. 【基础算法】二分法(二分答案,二分查找),三分法,Dinkelbach算法,算法详解+例题剖析

    目录 一 . 二分法 二分搜索得要求: 二分查找步骤: 二分答案: 玄学的二分(二分答案) 二 . 三分法 例题 三.01分数规划问题相关算法与题目讲解(二分法与Dinkelbach算法) 一 . 二 ...

  7. 洛谷P1182 数列分段Section II 二分答案

    洛谷P1182 数列分段Section II 二分答案 题意:将 n 个 数 分为 m段 求一种方案,使这m段中最大的和 最小 额..可能有点拗口,其实就是说每一种方案,都有对应的 每段和的最大值, ...

  8. 【枚举】【二分答案】【分块答案】【BFS】【最大流】【Dinic】bzoj1189 [HNOI2007]紧急疏散evacuate...

    [法一]枚举Time(0~N*M): S->'.'(1); 'D'->T(Time); '.'->'D'(dis(用BFS预处理,注意一旦到达'D',BFS就不能继续扩展了,注意di ...

  9. [Bzoj2282]消防(二分答案+树的直径)

    Description 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这个国家的人对火焰有超越宇宙的热情,所以这个国家 ...

最新文章

  1. R语言使用ggradar包可视化基本雷达图(radar chart、蜘蛛图spider plot)、可视化单个数据对象的雷达图
  2. iis同时运行asp和php,服务器IIS同时支持ASP和PHP
  3. 【Verilog HDL学习之路】第二章 Verilog HDL的设计方法学——层次建模
  4. BeyondCompare3提示许可密钥过期完美解决方法:3281-0350
  5. 在别的函数或者线程函数里使用 PostMessage
  6. if和else同时执行_为什么大量的if else这么不受待见?怎么“干掉”它?
  7. 编程实现strcpy函数_C编程中的strcpy()
  8. leetcode之移动零
  9. android arm linux下使用内存转储crash工具分析 kernel system dump问题
  10. java 解析ttf字体文件_stb_truetype解析ttf字体并将其保存到图片中
  11. 对于提高团队开会效率的看法
  12. Mac之间的 远程控制
  13. Common Data Model (CDM)通用数据模型1
  14. 基于python和Opencv将多张图片结合为一张图片的办法
  15. 公开的中文语料库有哪些?
  16. vue-cli模拟后台数据交互
  17. windows下文本转语音TTS库封装
  18. 会说话的读码器(Python实现)
  19. Clion配置Qt5环境
  20. 野火学习笔记(4) —— 固件库

热门文章

  1. 顺序表和链表实现图书管理系统
  2. Java类有个星号标记_Java中import包带*(星号)问题
  3. 雷军:从苦逼撸代码到年入上百亿,成为商界领袖,改变现状,只靠单纯写代码远远不够
  4. 海淘thinkpad-t460p攻略
  5. Docker容器的数据卷(volumes)
  6. MySQL数据库期末考试试题及参考答案(01)
  7. ZJM 与纸条(KMP算法)
  8. Arduino开发(二)_基于Arduino UNO开发板的RGB灯光控制方法
  9. 【Excel】Excel中实现中文转拼音(自定义函数方式)
  10. fullpage的使用方法及配置项 (慕课网视频总结)