(7.2)节:   递归问题   

1.题干:

递归方便表达,但是性能上消耗过多

1、有个小孩正在上楼梯,楼梯有n阶台阶,小孩一次可以上1阶、2阶、3阶。 请实现一个方法,计算小孩有多少种上楼的方式。

为了防止溢出,请将结果Mod 1000000007

给定一个正整数int n,请返回一个数,代表上楼的方式数。

保证n小于等于100000。

1、关键代码1:

int k2(int n)

{int rte=0;

if(n==1)

return 1;

if(n==2)

return 2;

if(n==3)

return 4;

return (k2(n-1)+k2(n-2)+k2(n-3))%1000000007;

}

关键代码2:

int  k2(int n)

{

int a[n+2];

int k;

a[0]=0;a[1]=1;a[2]=2;a[3]=4;

if(n==0)

k=0;

else if(n==1)

k=1;

else if(n==2)

k=2;

else if(n==3)

k=4;

else

for(int i=n;i<=n;i++)

{a[i]=(a[i-1]% 1000000007+a[i-2]% 1000000007+a[i-3])%1000000007;

k=a[i];

}

return k;

}

关键代码3:

int  k2(int n)

{int k=0;

if(n==0)

return 1;

if(n==1)

return 1;

if(n==2)

return 2;

if(n==3)

return 4;

int x1=1;

int x2=2;

int x3=4;

for(int i=4;i<=n;i++)

{int x_1=x1;

x1=x2;

x2=x3;

x3=x_1%1000000007+x2%1000000007+x1%1000000007;

k=x3%1000000007;

}

return k;

}

(7.3)节:   机器人走方格   

1.题干:有一个XxY的网格,一个机器人只能走格点且只能向右或向下走,要从左上角走到右下角。 请设计一个算法,计算机器人有多少种走法。

给定两个正整数int x,int y,请返回机器人的走法数目。

保证x+y小于等于12。

2、解答思路:从一开始找规律

3、关键代码1:

int k1(int x,int y)

{if(x==1||y==1)

return 1;

return k3(x-1,y)+k3(x,y-1);

}

关键代码2:

int k2(int x,int y)

{int a[x+1][y+1];

for(int i=1;i<=y;i++)

a[1][i]=1;

for(int i=1;i<=x;i++)

a[i][1]=1;

for(int i=2;i<=x;i++)

for(int j=2;j<=y;j++)

a[i][j]=a[i-1][j]+a[i][j-1];

return a[x][y];

}

(7.4)节:   硬币表示  

1、题干:假设我们有8种不同面值的硬币{1,2,5,10,20,50,100,200},用这些硬币组合够成一个给定的数值n。 例如n=200,那么一种可能的组合方式为 200 = 3 1 + 1*2 + 1*5 + 2*20 + 1 50 + 1 * 100. 问总共有多少种可能的组合方式?

2、解答思路:通过对靠近x的值进行分解,然后递归进行下一步分解

3、关键代码:

int a[8]={1,2,5,10,20,50,100,200};

int k3(int a[],int k,int x)//a为存储面值的数组,k为数组个数,x为给定数值n

{

if(x<=0)//刚好为倍数

return 1;

if(k==0)//只有一种走法;

return 1;

int max=0;

for(int i=0;i*a[k]<=x;i++)

{

max+=k3(a,k-1,x-i*a[k]);

}

return max;

}

int main()

{

int a[8]={1,2,5,10,20,50,100,200};

cout<<k3(a,8,10)<<endl;

return 0;

}

第【7】章: 数递归、DFS、剪枝、回溯等问题 学习报告的更多相关文章

  1. HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)

    Counting Cliques Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  2. LA 6476 Outpost Navigation (DFS+剪枝)

    题目链接 Solution DFS+剪枝 对于一个走过点k,如果有必要再走一次,那么一定是走过k后在k点的最大弹药数增加了.否则一定没有必要再走. 记录经过每个点的最大弹药数,对dfs进行剪枝. #i ...

  3. poj 1564 Sum It Up | zoj 1711 | hdu 1548 (dfs + 剪枝 or 判重)

    Sum It Up Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Sub ...

  4. 翻译连载 | 第 9 章:递归(下)-《JavaScript轻量级函数式编程》 |《你不知道的JS》姊妹篇

    原文地址:Functional-Light-JS 原文作者:Kyle Simpson-<You-Dont-Know-JS>作者 关于译者:这是一个流淌着沪江血液的纯粹工程:认真,是 HTM ...

  5. PKU 2531 Network Saboteur(dfs+剪枝||随机化算法)

    题目大意:原题链接 给定n个节点,任意两个节点之间有权值,把这n个节点分成A,B两个集合,使得A集合中的每一节点与B集合中的每一节点两两结合(即有|A|*|B|种结合方式)权值之和最大. 标记:A集合 ...

  6. poj 1011 :Sticks (dfs+剪枝)

    题意:给出n根小棒的长度stick[i],已知这n根小棒原本由若干根长度相同的长木棒(原棒)分解而来.求出原棒的最小可能长度. 思路:dfs+剪枝.蛮经典的题目,重点在于dfs剪枝的设计.先说先具体的 ...

  7. 历届试题 邮局(dfs+剪枝)

      历届试题 邮局   时间限制:1.0s   内存限制:256.0MB      问题描述 C村住着n户村民,由于交通闭塞,C村的村民只能通过信件与外界交流.为了方便村民们发信,C村打算在C村建设k ...

  8. 生日蛋糕 (poj1190) (dfs剪枝)

    [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1 <= i <= M)层蛋糕是半径为Ri, 高度为 ...

  9. *HDU1455 DFS剪枝

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

随机推荐

  1. app之功能测试

    1 什么是APP测试? App测试就是软件工程师对这类应用软件进行功能测试,性能测试,安全性测试以及兼容性测试等. 对于app测试我们一般采用的是黑盒测试方法,也会在必要的时候进行自动化测试以及性能测 ...

  2. 【树形dp】 Bzoj 4472 Salesman

    题目 某售货员小T要到若干城镇去推销商品,由于该地区是交通不便的山区,任意两个城镇 之间都只有唯一的可能经过其它城镇的路线. 小T 可以准确地估计出在每个城镇停留的净收 益.这些净收益可能是负数,即推 ...

  3. Docker文件系统实战

    关键词:Docker 联合文件系统 镜像 容器 云信私有化 在本文中,我们来实战构建一个Docker镜像,然后实例化容器,在Docker的生命周期中详细分析一下Docker的文件存储情况和Docker ...

  4. Emergency Evacuation 题解

    The Japanese government plans to increase the number of inbound tourists to forty million in the yea ...

  5. 切忌一步到位,谈谈DevOps实施落地

    2020年6月19日,由云计算开源产业联盟指导,高效运维社区和 DevOps 时代社区联合举办的GNSEC 2020线上峰会圆满举办.BoCloud博云参加了本次峰会并分享了博云帮助客户实施DevOp ...

  6. 【ASP.NET Core】mdl conflicts with tinymce

    When I implementd the popular Richtext Editor tinymce for this web application, it conflicts with ma ...

  7. C#远程连接代码

    /// <summary> /// 服务连接配置类(验证服务账号是否正确) /// </summary> /// <param name="remoteHost ...

  8. MySQL数据库06 /数据库总结

    MySQL数据库06 /数据库总结 目录 MySQL数据库06 /数据库总结 1. 数据库/DBMS 2. 数据库分类 3. 修改密码 4. 库操作 5. 表操作 6. 存储引擎 7. 事务 8. 约 ...

  9. redis(二十三):Redis 集群(proxy 型)二

    redis的确是一个非常高效的缓存服务器,但是单台redis服务器的内存管理能力有限,如果一味的加大内存的话会导致redis服务器的性能下降,所以就必须要搭建redis集群来提供服务.在redis官方 ...

  10. 渐进式Web应用(PWA)

    什么是渐进式Web应用? 渐进式Web应用是一种全新的Web技术,让Web应用和原生APP的体验相近或一致. 渐进式Web应用它可以横跨Web技术及Native APP开发的解决方案,对于开发者的优势 ...