Why so serious? --[NKU]schindlerlee

2010年1月31日星期日.ural1066-pku1759 二分答案,判断合法

2010年1月31日星期日.ural1066-pku1759

一道二分的题目

由题目中的递推式可以很容易的导出
 H[i+1] = 2 * H[i] + 2 - H[i-1]
然后我们可以二分枚举H[2]的值,判断是否成立,并且更新B值即可。

 1 
 2 const double eps = 1e-8;
 3 const int inf = 0x7fffffff;
 4 //http://www.cppblog.com/schindlerlee
 5 double B;
 6 int n;
 7 bool judge(double H1,double H2,int idx)
 8 {
 9   double H3 = 2*H2+2-H1;
10   if (H3 < 0) { return false; }
11   if(idx == n) {
12       B = min(B,H3);
13       return true;
14   }
15   return judge(H2,H3,idx + 1);
16 }
17 
18 int main()
19 {
20   B = inf;
21   double A;
22   int i,j,k;
23   scanf("%d %lf",&n,&A);
24   double left = 0,right = A;
25   while (left + eps < right) {
26       double mid = (left + right) / 2;
27       if(judge(A,mid,3)) {
28           right = mid;
29       }else {
30           left = mid;
31       }
32   }
33   printf("%.2f\n",B);
34   return 0;
35 }
36 
37 

posted on 2010-01-31 23:34 schindlerlee 阅读(997) 评论(0)  编辑 收藏 引用 所属分类: 解题报告


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理