首页 > 其他 > 详细

CodeForces 351A Jeff and Rounding

时间:2015-03-08 22:43:41      阅读:269      评论:0      收藏:0      [点我收藏+]

题意:给你一个2×n长的序列,进行n次操作,每次操作是选取两个从未选过的数,一个取上整,一个取下整,问你最后能得到最接近原来和的序列是多少。

解题思路:先将所有小数和统计出来,然后再枚举向下取整的个数即可 ,利用的原则是  x + (1-x) = 1; 

解题代码:

技术分享
 1 // File Name: 351a.cpg
 2 // Author: darkdream
 3 // Created Time: 2015年03月08日 星期日 12时21分23秒
 4 
 5 #include<vector>
 6 #include<list>
 7 #include<map>
 8 #include<set>
 9 #include<deque>
10 #include<stack>
11 #include<bitset>
12 #include<algorithm>
13 #include<functional>
14 #include<numeric>
15 #include<utility>
16 #include<sstream>
17 #include<iostream>
18 #include<iomanip>
19 #include<cstdio>
20 #include<cmath>
21 #include<cstdlib>
22 #include<cstring>
23 #include<ctime>
24 #define LL long long
25 
26 using namespace std;
27 int a[5000];
28 const double eps = 1e-8;
29 int main(){
30    int n ; 
31    scanf("%d",&n);
32    double sum = 0 ; 
33    int n0 = 0 ; 
34    for(int i = 1;i <= 2*n;i ++)
35    {
36       double tmp;
37       scanf("%lf",&tmp);
38       int x = (tmp*1000+eps);
39       a[i] = x % 1000;
40       if(a[i] == 0 )
41           n0 ++ ; 
42       sum += a[i]*1.0/1000;
43    }
44    double  ans = 1e9 ;
45  //  if(n == 32)
46    //printf("%f %d %d\n",ans,min(2*n-n0,n),n0);
47    for(int i = max(0,n-n0);i <= min(2*n-n0,n) ;i ++)
48        ans = min(ans,fabs(sum-i));
49    printf("%.3f\n",ans); 
50 return 0;
51 }
View Code

 

CodeForces 351A Jeff and Rounding

原文:http://www.cnblogs.com/zyue/p/4322306.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!