不容易系列之(3)—— LELE的RPG难题

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 15018    Accepted Submission(s): 5938

Problem Description
人称“AC女之杀手”的超级偶像LELE最近忽然玩起了深沉,这可急坏了众多“Cole”(LELE的粉丝,即"可乐"),经过多方打探,某资深Cole终于知道了原因,原来,LELE最近研究起了著名的RPG难题:

有排成一行的n个方格,用红(Red)、粉(Pink)、绿(Green)三色涂每个格子,每格涂一色,要求任何相邻的方格不能同色,且首尾两格也不同色.求全部的满足要求的涂法.

以上就是著名的RPG难题.

如果你是Cole,我想你一定会想尽办法帮助LELE解决这个问题的;如果不是,看在众多漂亮的痛不欲生的Cole女的面子上,你也不会袖手旁观吧?

Input
输入数据包含多个测试实例,每个测试实例占一行,由一个整数N组成,(0<n<=50)。
Output
对于每个测试实例,请输出全部的满足要求的涂法,每个实例的输出占一行。
Sample Input
12
Sample Output
36
Author
lcy

分析:假设有n个方格时涂法有f(n)种,在已有n-1个方格的情况下再增添第n个方格使得第n-1个方格由原来的最后一个方格成为倒数第二个方格,这样它可以选择的颜色种类有变化。起初方格n-1作为最后一个方格,它不能与方格1和方格n-2同色,此时,(1)当方格n-2与方格1同色时,n-1只需与n-2不同色即满足条件,注意此时方格n-1与方格1必不同色,因而加上第n个方格时,第n个方格的颜色已经确定了(作为最后一个方格,n只能涂与方格n-1、1不同的第三种色),既然如此,增加第n个方格对于总的涂法总数就没影响。(2)当方格n-2与方格1不同色时,起初方格n-1作为最后一个方格,由于要跟方格1和n-2不同,它可涂的颜色只有一种,而当加上方格n时,它就不需要和方格1不同,于是方格n-1可选的颜色种数+1,总的涂法总数加f(n-2),增加的这f(n-2)种涂法中,方格n-1均与方格1同色,此时方格n有两种颜色可选(因为只要跟方格n-1不一样就同时与方格1不一样),故增加的涂法为2*f(n-2),即f(n)比f(n-1)大2*f(n-2),递推关系:f(n)=f(n-1)+2*f(n-2),n>=4;这里n>=4是因为此时方格n-2不会是方格1

#include <iostream>
using namespace std;
int main()
{__int64 a[51]={0,3,6,6};int i;for(i=4;i<51;i++) a[i]=a[i-1]+2*a[i-2];while(cin>>i) printf("%I64d\n",a[i]);return 0;
}

转载于:https://blog.51cto.com/5666522/1341233

LELE的RPG难题相关推荐

  1. HDU2045 不容易系列之(3)—— LELE的RPG难题

    不容易系列之(3)-- LELE的RPG难题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/O ...

  2. HDU2045 不容易系列之(3)—— LELE的RPG难题(递推)

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission ...

  3. HDU-不容易系列之(3)—— LELE的RPG难题

    链接http://acm.hdu.edu.cn/showproblem.php?pid=2045 #include<stdio.h> int main() {int n,i;__int64 ...

  4. HDU 2045 不容易系列之(3)―― LELE的RPG难题(递推)

    题意:有排成一行的n个方格,用红(Red).粉(Pink).绿(Green)三色涂每个格子,每格涂一色,要求任何相邻的方格不能同色,且首尾两格也不同色.求全部的满足要求的涂法. 题解:本来当n=1时, ...

  5. linux shell脚本字符串连接符,学习Linux shell脚本中连接字符串的方法

    这篇文章主要介绍了Linux shell脚本中连接字符串的方法,如果想要在变量后面添加一个字符,可以用一下方法: 代码如下: $value1=home $value2=${value1}"= ...

  6. ACM训练赛--递推专题

    1001: Buy the Ticket Problem Description The "Harry Potter and the Goblet of Fire" will be ...

  7. 搜索打表大找规律 (hdu2045)

    不容易系列之(3)-- LELE的RPG难题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/O ...

  8. HDU1465 不容易系列之一【递推】

    不容易系列之一 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Su ...

  9. HDU2050 折线分割平面【组合】

    折线分割平面 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

最新文章

  1. 国内自动驾驶公司争先入局Robotaxi
  2. win7网络适配器_Win7系统笔记本电脑连接蓝牙音箱的操作方法
  3. layui表格 设置默认排序_layui table对表格数据处理后的排序问题
  4. 【学习笔记】浅谈广义矩阵乘法——动态DP
  5. 神龙X-Dragon,这技术“范儿”如何?| 问底中国IT技术演进
  6. OPPO 人像视频黑科技新鲜出炉,下月就换手机!
  7. Windows7 共享文件夹不能访问(原创)
  8. JQuery simpleModal插件的使用-遁地龙卷风
  9. 【转】STL中map用法详解
  10. java jdk 安装教程_JDK下载安装配置教程(详细)
  11. 维宏v8系列卡win7/win10 64位驱动
  12. SSIM公式:结构相似性计算原理,基于SSIM的图像质量评价
  13. 教育教学教师竞聘说课PPT模板
  14. 华为2019实习生机试题1
  15. 聊一聊为什么JAVA只允许单继承
  16. 利用IE的追踪保护加载项,给IE增加去广告功能
  17. HTML中的meta标签
  18. win10 使用wireshark抓包本地localhost请求
  19. 计算机安全的基本概念,计算机安全包括哪几个方面
  20. MySQL的MDL元数据锁

热门文章

  1. 快速构建Windows 8风格应用31-构建磁贴
  2. 邮件列表统计(网站推广)
  3. myeclipse中的classpath .
  4. SpringSecurity常用过滤器介绍
  5. 自定义镜像-Dockerfile
  6. Feign-自定义配置
  7. Nginx七层负载均衡的案例
  8. RoundRobinAssignor(轮询分区)
  9. 高仿真的类-BeanDefinitionReader
  10. 分布式文件系统研究-fastDSF文件上传和下载流程