首页 > 代码库 > 车站——斐波那契(再做做)
车站——斐波那契(再做做)
题目描述
火车从始发站(称为第1站)开出,在始发站上车的人数为a,然后到达第2站,在第2站有人上、下车,但上、下车的人数相同,因此在第2站开出时(即在到达第3站之前)车上的人数保持为a人。从第3站起(包括第3站)上、下车的人数有一定规律:上车的人数都是前两站上车人数之和,而下车人数等于上一站上车人数,一直到终点站的前一站(第n-1站),都满足此规律。现给出的条件是:共有N个车站,始发站上车的人数为a,最后一站下车的人数是m(全部下车)。试问x站开出时车上的人数是多少?
输入输出格式
输入格式:
a(<=20),n(<=20),m(<=2000),和x(<=20),
输出格式:
从x站开出时车上的人数。
输入输出样例
输入样例#1:
5 7 32 4
输出样例#1:
13
解法一:暴力枚举(有点不靠谱,由于测试数据太水,竟让我给水过了)
#include<cstdio>#include<cstdlib>#include<iostream>#include<algorithm>using namespace std;int read(){ int x=0,f=1; char ch=getchar(); while(ch<‘0‘||ch>‘9‘) { if(ch==‘-‘) f=-1; ch=getchar(); } while(ch>=‘0‘&&ch<=‘9‘) { x=x*10+ch-‘0‘; ch=getchar(); } return f*x;}int main(){ int a=read(),n=read(),m=read(),b=read(); int on[21],oncar[21],down[21]; on[1]=a; oncar[1]=a; for(int i=0;;i++) { on[2]=i; oncar[2]=a; down[2]=i; for(int j=2;j<=n-1;j++) { oncar[j]=oncar[j-1]+on[j]-down[j]; on[j+1]=on[j-1]+on[j]; down[j+1]=on[j]; } if(oncar[n-1]==m) break; } printf("%d\n",oncar[b]); return 0;}
法二:
通过分析题目我们可以发现以下规律
以下是上车人数的规律
通过观察上述表格会发现:红色部位和蓝色部位都是斐波那契数列耶!!
那就好玩了
这样我们就可以推出这样一个方程
上车人数=f(x-2)a+f(x-1)t
车上人数的规律
也就是说
车上人数=前一站人数+上两站人数(1站);
废话少说,下面提供蒟蒻代码
#include <iostream>#include <cstdio>#include <algorithm>#include <cstring>#include <string>using namespace std;int main(){ int a,b,n,m,x,fibo[21]={0}; scanf("%d%d%d%d",&a,&n,&m,&x); fibo[0]=0;fibo[1]=1; for(int i=2;i<=n;i++) fibo[i]=fibo[i-1]+fibo[i-2]; //f[n-1]=fibo[n-2]*b+fibo[n-3]*a //m=fibo[n-2]*b+fibo[n-3]*a+a-b //m=(fibo[n-2]-1)*b+(fibo[n-3]+1)*a b=(m-(fibo[n-3]+1)*a)/(fibo[n-2]-1); printf("%d",(fibo[x-1]-1)*b+(fibo[x-2]+1)*a);}
车站——斐波那契(再做做)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。