NOJ1113 斐波那契数应用 模拟
2015-06-10 00:34
344 查看
题目描述
知道斐波那契数吗?下面是它的一个定义:F1 = 1
F2 = 2
Fn+1 = Fn+Fn-1 ,这里n>1
每个正整数x 可写为不同斐波那契数的总和,因而意味着存在数k 和数 b1, b2, …, bk,使得x=b1*F1+ …+ bi*Fi+ … +bk*Fk, 其中bk = 1,bi (1≤i < k)为0或1。简言之,我们可写为: b(x) = (bk, bk-1, …, b1)。 为使表示唯一,我们要求对所有i > 1,bi * bi-1 = 0。
利用斐波那契数,我们可以将公里单位距离 x 转换为相应的英里单位距离 y,首先,以斐波那契系统表示b(x)写下x。其次,将b(x)中数字右移一位(最后一位删除),得到b(y)。第三,从b(y)中计算总数来算出 y。
例如,数42以斐波那契系统表示为:(1,0,0,1,0,0,0,0)。第二步,我们通过右移得到 (1,0,0,1,0,0,0)。第三步,我们计算0*1 + 0*2 + 0*3 + 1*5 + 0*8 + 0*13 + 1*21 = 26.
下面请你写一个程序,根据上述算法将公里转换为英里。
输入
输入第一行包含t,需要转换的距离数目 (0输出
对于每个距离x 公里,输出算出的y 英里。样例输入
542
100
180
300
360
样例输出
2662
111
185
222
思路
模拟….本来想直接拿换算公式过来套,发现和题目有误差 = = 大水题代码
[code]#include <cstdio> #include <cstring> #include <algorithm> #include <cmath> using namespace std; const int maxn = 23; int f[maxn]; int n; bool used[maxn]; int main() { f[1] = 1; f[2] = 2; for(int i = 3 ; i < maxn ; i ++) f[i] = f[i-1]+f[i-2]; int t; scanf("%d",&t); while(t--) { scanf("%d",&n); int pt; fill(used,used+maxn,false); for(pt = 1 ; pt < maxn ; pt ++) { if(f[pt] > n) break; } used[pt-1] = true; int tmp = f[pt-1]; for(int i = pt-2 ; i >= 1 ; i --) { if(tmp == n) break; if(used[i+1]) { continue; }else { if(f[i]+tmp <= n) { tmp += f[i]; used[i] = true; } } } int ans = 0; for(int i = 2 ; i < maxn ; i ++) { if(used[i]) ans += f[i-1]; } printf("%d\n",ans); } return 0; }
相关文章推荐
- spring mvc 注解基本配置(@resource,@autowired,@Component...)
- MATLAB代码
- 【ios开发学习 - 第四课】UIButton使用
- head,tail,cat,more,less
- head,tail,cat,more,less
- [数据结构]前言——概述
- nginx那些强大的不可不说的功能
- hihocode第49周1001欧拉路一
- jquery判断checked的三种方法
- win7让任务栏中的文件夹图标打开的是我的电脑
- 多态图形
- JavaBean及其两种使用方式
- 【吾日三省吾身】2015.6.09-涅槃行动第二十二天
- Erlang的算法-(二)合并排序/归并排序
- 以前(2009年10月5日)保存的一些以前觉得好的语句
- (实验6)编写统计字符出现次数函数
- 给挫折一个微笑
- 据说,年薪百万的程序员,都是这么开悟的(一)
- 把简单的事做到极致
- android 实践问题记录- 2015/06/09