acm 弱渣不会水题(1)--(HDU 2501)
来源:互联网 发布:大疆无人机 知乎 编辑:程序博客网 时间:2024/04/27 07:56
- Tiling_easy version
- 分析
俗话说得好,水水更健康,水水更开心。。。
然而水题不是那么好做的,呜呜。。。
递推是很多人的弱项,比如我。
Tiling_easy version
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 7671 Accepted Submission(s): 5929
Problem Description
有一个大小是 2 x n 的网格,现在需要用2种规格的骨牌铺满,骨牌规格分别是 2 x 1 和 2 x 2,请计算一共有多少种铺设的方法。
Input
输入的第一行包含一个正整数T(T<=20),表示一共有 T组数据,接着是T行数据,每行包含一个正整数N(N<=30),表示网格的大小是2行N列。
Output
输出一共有多少种铺设的方法,每组数据的输出占一行。
Sample Input
3
2
8
12
Sample Output
3
171
2731
分析
n=1时,f(n)=1;
n=2时,f(n)=3;
n=3时,f(n)=5;
……
假设2*n个空间,已知a[n-1]和a[n-2]。(宽2,长n)
(1)先把2*(n-1)放好,那么剩余的2*1的空间只能放一个竖放的2*1,这里有a[n-1]种
(2)、先把2*(n-2)放在空间的上方,那么剩余的2*2的空间可以放两个2*1,两个竖放的2*1,一个2*2,共3种,但是,注意的是,两个竖放的2*1这种情况与(1)的重复,so,只有两种情况符合,这里有2*a[n-2]种
so,a[n]=a[n-1]+2*a[n-2]
代码如下:
#include<stdio.h>int main(){ long a[32]; int n, b; a[0] = 1; a[1] = 3; for (int i = 2; i < 31; i++) a[i] = a[i - 1] + 2 * a[i - 2]; while (scanf("%d", &n) == 1) { while (n--) { scanf("%d", &b); printf("%ld\n", a[b - 1]); } } return 0;}
- acm 弱渣不会水题(1)--(HDU 2501)
- acm 弱渣不会水题(2)--(HDU 2502)
- acm 弱渣不会水题(3)--(HDU 2504)
- HDU ACM 2222->AC自动机模版题(入门题)
- hdu ACM Steps 做题笔记(Chapter One)
- A/B(数论水题) hdu ACM 1576 c++
- [ACM] hdu 3549 Flow Problem (最大流模板题)
- hdu ACM Steps 做题笔记(Chapter Two)(Section 1)
- hdu acm 1907 John(涉及到博弈论)
- [ACM] hdu Wall (凸包周长)
- [ACM] hdu 1846 Brave Game (巴什博奕)
- [ACM] hdu 2149 Public Sale (巴什博奕)
- [ACM] hdu 1521 排列组合(组合+DFS)
- [ACM] hdu 1241 Oil Deposits(DFS)
- [ACM] hdu 2795 Billboard (线段树)
- [ACM] hdu 2352 Stars (树状数组)
- [ACM] hdu 2844 Coins (多重背包)
- [ACM] hdu 1260 Tickets (动态规划)
- c++中浮点数的存储方式
- 斯特林数的研究
- 使用SSH时提示 ”Server responded "Algorithm negotiation failed"
- 数据库ID---转载自http://www.cnblogs.com/kissdodog/archive/2013/05/28/3102862.html
- MVC,MVP,MVPVM(二)提升效率之Templates
- acm 弱渣不会水题(1)--(HDU 2501)
- ORACLE概要文件
- 安装VirtualBox的时候遇到的问题
- Python标准库(三)
- 命令行提示符修改(环境变量PS1)
- Winform解决闪屏问题
- 计算机中的文字编码
- FileReader FileWriter 的用法读取文件内容
- 干货 | 扫了那么多二维码,15款工具打造你的专属二维码