hdu 1316 How Many Fibs?
2015-08-13 17:27
246 查看
题目(http://acm.hdu.edu.cn/showproblem.php?pid=1316)
求a到b之间有多少个斐波那契数,数很大只能用高精度
Problem Description Recall the definition of the Fibonacci numbers: f1 := 1 f2 := 2 fn := fn-1 + fn-2 (n >= 3) Given two numbers a and b, calculate how many Fibonacci numbers are in the range [a, b]. Input The input contains several test cases. Each test case consists of two non-negative integer numbers a and b. Input is terminated by a = b = 0. Otherwise, a <= b <= 10^100. The numbers a and b are given with no superfluous leading zeros. Output For each test case output on a single line the number of Fibonacci numbers fi with a <= fi <= b. Sample Input 10 100 1234567890 9876543210 0 0 Sample Output 5 4
求a到b之间有多少个斐波那契数,数很大只能用高精度
#include <iostream> #include <cstring> #include <cstdio> using namespace std; string add(string s1,string s2) { if(s1.length()<s2.length()) { string temp=s1; s1=s2; s2=temp; } for(int i=s1.length()-1,j=s2.length ()-1;i>=0;i--,j--) { s1[i]=char(s1[i]+(j>=0?s2[j]-'0':0)); if(s1[i]-'0'>=10) { s1[i]=char((s1[i]-'0')%10+'0'); if(i) s1[i-1]++; else s1='1'+s1; } } return s1; } string f[1005],a,b; int main() { int i; f[1]='1'; f[2]='2'; for(i=3;i<1005;i++) f[i]=add(f[i-2],f[i-1]);//打表 while(cin>>a>>b) { if(a=="0"&&b=="0") break; int left,right,cnt = 0,len_a,len_b,len; len_a=a.length(); len_b=b.length(); for(i=1;i<1005;i++) { len=f[i].length(); if(len<len_a) continue; else if(len==len_a&&f[i]>=a) { left=i; break; } else if(len>len_a) { left=i; break; } } for(i=1004;i>=1;i--) { len=f[i].length(); if(len>len_b) continue; else if(len==len_b&&f[i]<=b) { right=i; break; } else if(len<len_b) { right=i; break; } } printf("%d\n",right-left+1); } return 0; }
相关文章推荐
- NB多项式模型、神经网络、SVM初步—斯坦福ML公开课笔记6
- CSS3选择器学习笔记
- ubuntu安装ulipad
- 邓小平文选第三卷辅导讲座
- 调用百度语音SDK,简单的语音识别控件
- 关于无线PCB中 中50欧姆的特性阻抗的注意事项
- android 图片上传,使用 httpclient 的MultipartEntity 上传
- CMD命令不能运行
- Linux Ubuntu 环境变量修改及生效方法
- IOS BLE4.0蓝牙和外设连接和收发数据的流程
- uC/OS-II中OSUnMapTbl[]的原理
- asp.net Cache vs memcached
- 【NOI2015Day1】【bzoj4195】【bzoj4196】【bzoj4197】
- 【dp】【NOI 2015】【bzoj 4197】寿司晚宴
- MFC 单文档去掉标题栏和菜单栏
- 解决模拟弹出框情况下文档滚动的问题
- Swift UI学习UITableView and protocol use
- discuz编辑器
- Activiti流程图部署及流程图部分操作
- [转]df命令