2013腾讯马拉松编程初赛3月25日1001(HDU4525)
2013-03-26 15:21
393 查看
/*
坑爹的以为什么k,k1,k2,啥子的都是整数类型;没想到居然会有小数;难怪张大牛wa了那么多次硬是没过;
怪就怪自己审题不注意吧;一般题目对数据类型说的还是会比较清楚的,这次对题目类型的描述是 每组数据的第一行包含4个数字n,k1,k2,k,
除了n以外,其他的都可能为小数,所以还是定义为double为妙(事实证明不这样做是会贡献WA 的);
其实函数就是 sum = (k1+k2)*sum; 累积起来就是个指数函数 sum*(k1+k2)^n 对于指数函数的性质,可以根据图像分析
对于特殊情况(可能一直达不到k的情况 以及 一开始就超过k的情况)特殊分析,这些都注意的,其实还是挺简单的;
*/
坑爹的以为什么k,k1,k2,啥子的都是整数类型;没想到居然会有小数;难怪张大牛wa了那么多次硬是没过;
怪就怪自己审题不注意吧;一般题目对数据类型说的还是会比较清楚的,这次对题目类型的描述是 每组数据的第一行包含4个数字n,k1,k2,k,
除了n以外,其他的都可能为小数,所以还是定义为double为妙(事实证明不这样做是会贡献WA 的);
其实函数就是 sum = (k1+k2)*sum; 累积起来就是个指数函数 sum*(k1+k2)^n 对于指数函数的性质,可以根据图像分析
对于特殊情况(可能一直达不到k的情况 以及 一开始就超过k的情况)特殊分析,这些都注意的,其实还是挺简单的;
*/
#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> #include <cmath> #include <string> #include <iomanip> using namespace std; int main(int argc, char *argv[]) { int t,n,ca = 0; double k1,k2,k,a; scanf("%d",&t); while(t--) { ca++; scanf("%d%lf%lf%lf",&n,&k1,&k2,&k); double sum = 0.0; for(int i = 1; i <= n; i++) { scanf("%lf",&a); sum += a; } if(sum>k) { printf("Case #%d: 0\n",ca); continue; } if(((k1+k2)<=0&&(k1+k2)>=-1&&sum*(k1+k2)<=k)||(sum<=0&&sum>=-1&&sum*(k1+k2)<=k)) { printf("Case #%d: inf\n",ca); continue; } int i = 0; //printf("sum:%d\n",sum); while(sum <= k) { sum = (k1+ k2) * sum; i++; } printf("Case #%d: %d\n",ca,i); } return 0; }
相关文章推荐
- 2013腾讯马拉松编程初赛3月25日1001(HDU4525)
- 2013腾讯编程马拉松初赛第五场(3月25日)
- 2013腾讯马拉松编程初赛3月23日1001
- 2013腾讯马拉松编程初赛3月23日1001
- 2013腾讯马拉松编程初赛3月22日1001
- 2013腾讯马拉松编程初赛3月22日1001
- 2013腾讯马拉松编程初赛3月20日1001
- HDU(4528),BFS,2013腾讯编程马拉松初赛第五场(3月25日)
- 2013腾讯马拉松编程初赛3月20日1001
- 2013腾讯编程马拉松初赛 20130320第一场1001 小Q系列故事——屌丝的逆袭 简单题
- 2013腾讯马拉松编程初赛3月21日1001
- 2013腾讯马拉松编程初赛3月21日1001
- 2013腾讯编程马拉松初赛第〇场(HDU 4503) 湫湫系列故事——植树节
- 2013腾讯编程马拉松初赛(3月22)赛题及第2题代码(C++)
- 湫湫系列故事——植树节(2013腾讯编程马拉松初赛)
- 2013腾讯编程马拉松初赛
- hdu4507恨7不成妻(数位dp) 2013腾讯编程马拉松初赛第一场
- 2013腾讯编程马拉松初赛第一场(3月21日)湫湫系列故事——减肥记II
- HDU 4508 湫湫系列故事——减肥记I (2013腾讯编程马拉松初赛第一场)
- 值得思考的一道题 2013腾讯编程马拉松初赛 HDU 4503