首页 技术 正文
技术 2022年11月17日
0 收藏 963 点赞 3,741 浏览 841 个字

车站每站的上车人数,下车人数,剩余人数都组成了斐波那契数列

此代码只计算了剩余人数的情况,所以在输入需要总站数量时会-1取上一站的剩余人数

(最后一站会全部下车,没有上车人数)

每一站的剩余人数都可以用两个斐波那契数列表示

虽然数列的算法一样,但是初始值不同

import java.util.Scanner;public class D2 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int a=sc.nextInt(); //第一站上车人数
int n=sc.nextInt(); //总站数
int m=sc.nextInt(); //最后一站剩余人数
int x=sc.nextInt(); //求x站人数
int y=0;
//特殊情况
n-=1;
if (n<3||x<2){
System.out.print(a);
return;
}else if (n==3||x==2){
System.out.print(2*a);
return;
}else if (n==4){
y=m-(2*a);
}
//y的递增趋势斐波那契数列
int[] fib=new int[20];
fib[0]=0;
fib[1]=1;
fib[2]=2;
//a的递增趋势斐波那契数列
int[] fib1=new int[20];
fib1[0]=0;
fib1[1]=1;
fib1[2]=1;
fib1[3]=2;
for (int i = 3; i < fib.length; i++) {
fib[i]=fib[i-1]-fib[i-2]+fib[i-2]-fib[i-3]+fib[i-1];
fib1[i]=fib1[i-1]-fib1[i-2]+fib1[i-2]-fib1[i-3]+fib1[i-1];
} if (n>4){
y=(m-((fib1[n-2]+1)*a))/fib[n-3];
}
int b=((fib1[x-2]+1)*a)+fib[x-3]*y;
System.out.println(b); }
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,084
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,559
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,408
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,181
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,818
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,901