一天一道算法题---6.3---二分运用

感谢微信平台 : 一天一道算法题 -----  一天多一点进步-----

先来段 废话:

已经 3 4天没更了 主要还是自己 太懒了 。。。。

好 让我们 开始吧

题目链接:

          touch 
me

是不是 有点长啊  最可恶的是 还有张 诱人的 馅饼  ---

        话说 有个很好的美国系列校园青春 sex movie ---  American Pie  ---
美国派-----

题目大意:

  有F+1个人来分N个圆形蛋糕 每个人得到的必是一整块蛋糕 (不是由几块拼在一起的)面积要相同 求每个人最多能得到多大面积的蛋糕 (
不必是圆形)

tips:

  这有点类似 你在寻找一个明确范围内寻找一个适合它的最大即最优的解

  既然我已经指明了 使用 二分思想 那么你只要知道 一个半径为R的蛋糕 只能切出 ( π * r * r )/(S)
这里的S就是你要分给每个人的蛋糕的面积 因为蛋糕不能是由几个蛋糕拼起来的 那么可以确定 可以划分的蛋糕 就是  cnt = (
π*r*r)/(S)的总和  这里的cnt 需要向下取整 就是 如果3.5 就取 3 就这意思

  好了 负罪感 down

  贴上我的代码:

 

 1 #include <iostream>
2 #include <cstdio>
3 #include <cmath>
4 #include <cstring>
5 using namespace std;
6
7 int n , m;
8 const int size = 10010;
9 const double pi = 3.1415926535898 ;
10 double area[size];
11
12 bool choose( double s )
13 {
14 int sum = 0;
15 for( int i = 0 ; i<m ; i++ )
16 {
17 sum+=floor(area[i]/s); //向下取整 3.5->3 人总是整数的
18 }
19 return sum>=n+1; //这是个很好的细节 相比你去写 If....else... 简洁 即美
20 }
21
22 int main()
23 {
24 int t;
25 double l , r , mid , mmax;
26 scanf( "%d",&t );
27 while( t-- )
28 {
29 memset( area , 0 , sizeof(area) );
30 mmax = 0;
31 scanf( "%d %d",&m,&n );//n+1个人 m个蛋糕 一开始 顺序弄错了
32 for( int i = 0 ; i<m ; i++ )
33 {
34 scanf( "%lf",&area[i] );
35 area[i] = area[i]*area[i]*pi;
36 if( area[i]>mmax ) //找出这m块蛋糕的
37 mmax = area[i];
38 }
39 l = 0;
40 r = mmax;
41 while( r-l>1e-5 )
42 {
43 mid = l + (r-l)/2;
44 if( choose(mid) )
45 l = mid;
46 else
47 r = mid;
48 }
49 printf( "%.4lf\n",l );
50 }
51 return 0;
52 }

today:

  最难得到的两个字叫简单,最难解释的两个字叫幸福,简单即幸福,简单的幸福。

一天一道算法题---6.3---二分运用

时间: 2024-10-09 23:29:44

一天一道算法题---6.3---二分运用的相关文章

一天一道算法题---6.26---二分查找

感谢微信平台---一天一道算法题----每天多一点进步-- 好累啊  现在在用win7自带的输入法 打起来真麻烦 快点把这2天的搞完就重装了 还是直接来源于----〉 待字闺中 分析 给定一个数组A,其中有一个位置被称为Magic Index,含义是:如果i是Magic Index,则A[i] = i.假设A中的元素递增有序.且不重复,请给出方法,找到这个Magic Index.更进一步,当A中允许有重复的元素,该怎么办呢? 没有重复元素的情况 一些同学在遇到这个题目的时候,往往会觉得比较简单.

一天一道算法题--6.25--无定义

感谢微信平台---一天一道算法题--每天多一点进步---- 其实今天我接下去补上的几题都来自---待字闺中 所以我就原封不动的将它的题目与分析搬过来了 原题 给定一个数组,我们可以找到两个不相交的.并且是连续的子数组A和B,A中的数字和为sum(A), B中的元素和为sum(B).找到这样的A和B,满足sum(A) - sum(B)的绝对值是最大的. 例如:[2, -1 -2, 1, -4, 2, 8]划分为A=[-1, -2, 1, -4], B=[2, 8], 最大的值为16 分析 如果没有

一天一道算法题---6.27---二分图

感谢微信平台---一天一道算法题---每天多一点进步--- Ah... last... 也很晚了 快2点半了 C罗也告别这届世界杯了  主要还是输给德国太多球了 美国也没赢 唉 还是来源于----> 待字闺中 原题 大家都知道facebook用户都是双向的好友,a是b的好友,那么b一定是a的好友,现在给定一个用户列表,其中有些用户是好友,有些不是,请判断,这些用户是否可以划分为两组,并且每组内的用户,互相都不是好友.如果能,请给出这个划分. 例子1: 用户:{1, 2, 3} 好友关系:1-2,

前端面试的一道算法题

(使用canvas解答) 下面说一个跟前端有点相关并且有点趣的一道算法题. 题目: 平面上有若干个不特定的形状,如下图所示.请写程序求出物体的个数,以及每个不同物体的面积. 分析 想要知道有多少个图形,想到的就是先获取图片中的每一个像素点然后判获取像素点的背景颜色(RGBA).想要获得图片中的每一个像素点,那就可以联想到使用h5的canvas.如下: 菜鸟教程中canvas的getimagedata方法http://www.runoob.com/tags/canvas-getimagedata.

一天一道算法题--6.19--二分搜索

感谢微信平台---一天一道算法题---每天多一点进步 这是昨天的 只贴下题目 == 再把今天的也是一样处理了   这2天 不想写 可能晚上会有改变吧.. problem: 给定一个最多包含40亿个随机排列的32位 二进制的无符号整数 找出不在文件中的数.显然 由于 2^32=4294967196大于4亿 所以缺少的数不止一个 现限制只能使用几个外部的临时文件和仅几百个字节的内存. ****************************** 过了明天 就没事了 =-= 一天一道算法题--6.19

一天一道算法题--6.13---计算几何

感谢微信平台---一天一道算法题---每天多一点进步 本来 想在世界杯之前 可以 开开心心地A了今天的算法题  .... 竟然是计算几何 我高数 那么渣....... 这题 先放着吧..... 哎.... 链接 还是一样先放出来 . touch me 平常这个点 再过会 就应该要碎觉了 今天 = 个揭幕战 累死我的节奏,,, 现在去做点什么呢........... 一天一道算法题--6.13---计算几何,布布扣,bubuko.com

一天一道算法题--5.29---动态规划之数塔

感谢微信平台:  一天一道算法题-------每天多一点进步----------- 这题的话 我就直接用我们自己Oj的题目了 戳我 好吧  如今看这题  是很简单  当时 是块被它搞崩溃了   因为 还不知道  dp 这个概念 现在有了这个概念   好多了  但还是 只能做做这种水 dp.... 多么悲伤的故事 这题 因为太水了   晚上 应该会去找个高质量的题来做的 如果你是dp刚刚学 这题真的很适合你 1 #include <iostream> 2 #include <cstring

每天一道算法题:数字二进制形式中1的个数

题目:请实现一个函数,属于一个整数,输出该数二进制表示中1的个数,例如把9表示成二进制是1001,有2位为1.因此如果输入9,该函数输出2. 可能的死循环陷阱 看完题目,相信大家很快就能想到一个解题思路:先判断整数二进制表示中最右边的一位是否为1,接着把输入的整数右移一位,此时原来处于从右边起的第二位被移动至最右边了,再判断是不是1,这样每次移动一位,直到这个整数变成0,即能够得到整数二进制表示形式中1的个数,而现在问题变为如何判断数字的最后一位为1,其实这个也很简单,只需要将数字与1做与运算,

一天一道算法题---6.16--最大独立集

感谢微信平台---一天一道算法题---每天多一点进步 这题 我都懒得贴了.... 因为 很巧合的是 我已经做过他了 我也详细地讲过自己的 颠沛 做这题时 要是 感兴趣 可以去找下 我的随笔 -- 前面的记录 a good news ---- 昨晚和晓爷 一起看的那个 蛮有意思的阶乘AC了  但还有个关于阶乘 17/0 的题 =-= 跑步去了 身体太虚 萎 ... 一天一道算法题---6.16--最大独立集,布布扣,bubuko.com