hdu 2569 彼岸
2015-08-19 00:10
393 查看
总结:典型的递归题,主要看后面两块。
假设第n-2块有a种方法,第n-1块有b种方法(a<=b)。
若第n-2块和第n-1块颜色一样,则a==b,第n块有3*a种方法;
若第n-2块和第n-1块颜色不同,则第n-2块有a种方法,且第n-1块有b-a种方法,第n块有2*(b-a)种方法。
那么f(n) = 2* f(n-1) + f(n-2);
java代码:
Total Submission(s): 3609 Accepted Submission(s): 2045
Problem Description
突破蝙蝠的包围,yifenfei来到一处悬崖面前,悬崖彼岸就是前进的方向,好在现在的yifenfei已经学过御剑术,可御剑轻松飞过悬崖。
现在的问题是:悬崖中间飞着很多红,黄,蓝三种颜色的珠子,假设我们把悬崖看成一条长度为n的线段,线段上的每一单位长度空间都可能飞过红,黄,蓝三种珠子,而yifenfei必定会在该空间上碰到一种颜色的珠子。如果在连续3段单位空间碰到的珠子颜色都不一样,则yifenfei就会坠落。
比如经过长度为3的悬崖,碰到的珠子先后为 “红黄蓝”,或者 “蓝红黄” 等类似情况就会坠落,而如果是 “红黄红” 或者 “红黄黄”等情况则可以安全到达。
现在请问:yifenfei安然抵达彼岸的方法有多少种?
![](http://acm.hdu.edu.cn/data/images/C164-1003-1.jpg)
![](http://acm.hdu.edu.cn/data/images/C164-1003-2.jpg)
Input
输入数据首先给出一个整数C,表示测试组数。
然后是C组数据,每组包含一个正整数n (n<40)。
Output
对应每组输入数据,请输出一个整数,表示yifenfei安然抵达彼岸的方法数。
每组输出占一行。
Sample Input
Sample Output
Author
yifenfei
Source
ACM程序设计期末考试081230
Recommend
yifenfei | We have carefully selected several similar problems for you: 2571 2570 2572 2544 2190
假设第n-2块有a种方法,第n-1块有b种方法(a<=b)。
若第n-2块和第n-1块颜色一样,则a==b,第n块有3*a种方法;
若第n-2块和第n-1块颜色不同,则第n-2块有a种方法,且第n-1块有b-a种方法,第n块有2*(b-a)种方法。
那么f(n) = 2* f(n-1) + f(n-2);
java代码:
import java.util.Scanner; public class Main { public static void main(String[] args) { /* * 打表法 * 用long型,防止超出int范围 */ long arr[] = new long[40]; arr[1] = 3; arr[2] = 9; arr[3] = 21; for (int i = 4; i < arr.length; i++) { arr[i] = 2 * arr[i - 1] + arr[i - 2]; } Scanner sc = new Scanner(System.in); int c, n; c = sc.nextInt(); while (c-- > 0) { n = sc.nextInt(); System.out.println(arr ); } } }
彼岸
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3609 Accepted Submission(s): 2045
Problem Description
突破蝙蝠的包围,yifenfei来到一处悬崖面前,悬崖彼岸就是前进的方向,好在现在的yifenfei已经学过御剑术,可御剑轻松飞过悬崖。
现在的问题是:悬崖中间飞着很多红,黄,蓝三种颜色的珠子,假设我们把悬崖看成一条长度为n的线段,线段上的每一单位长度空间都可能飞过红,黄,蓝三种珠子,而yifenfei必定会在该空间上碰到一种颜色的珠子。如果在连续3段单位空间碰到的珠子颜色都不一样,则yifenfei就会坠落。
比如经过长度为3的悬崖,碰到的珠子先后为 “红黄蓝”,或者 “蓝红黄” 等类似情况就会坠落,而如果是 “红黄红” 或者 “红黄黄”等情况则可以安全到达。
现在请问:yifenfei安然抵达彼岸的方法有多少种?
![](http://acm.hdu.edu.cn/data/images/C164-1003-1.jpg)
![](http://acm.hdu.edu.cn/data/images/C164-1003-2.jpg)
Input
输入数据首先给出一个整数C,表示测试组数。
然后是C组数据,每组包含一个正整数n (n<40)。
Output
对应每组输入数据,请输出一个整数,表示yifenfei安然抵达彼岸的方法数。
每组输出占一行。
Sample Input
2 2 3
Sample Output
9 21
Author
yifenfei
Source
ACM程序设计期末考试081230
Recommend
yifenfei | We have carefully selected several similar problems for you: 2571 2570 2572 2544 2190
相关文章推荐
- Linux中使用京东代码库JDCode创建私有Git仓库
- FragmentTransaction add 和 replace 区别
- sun.misc.BASE64Decoder 限制取消
- [转]图解分布式一致性协议Paxos
- Perl学习(三)
- Android通过startService播放背景音乐简单示例
- Winodows10 安全登录(Administrator账户与Microsoft Account关联
- xcode 6.0 Alcatraz安装无法出现Package Manager
- 猜生日
- c++打印心形
- pat(A) 07-排序1. 排序(水题)
- sqlalchemy(一)基本操作
- linux gpio 控制 基于 sysfs
- 生活的哲学:高尔夫球和啤酒
- Mysql索引
- UI基本控件
- IIS处理浏览器请求的流程 | 应用程序的生命周期
- 希尔排序
- 每 172 个活动 RSA 证书中就有一个容易受到攻击
- 使用 rsync 复制大文件的一些误解