猴子摘香蕉问题python_硬币找零&&爬楼梯&&猴子摘香蕉「建议收藏」

猴子摘香蕉问题python_硬币找零&&爬楼梯&&猴子摘香蕉「建议收藏」硬币找零&&爬楼梯&&猴子摘香蕉假设有几种硬币,如1、3、5,并且数量无限。请找出能够组成某个数目的找零所使用最少的硬币数。#include”CoinProblem.h”#includeintcountNum=MAX;voidCoinProblem(int*coin,intLength,intValue,intcount){if(Value==0){if(count…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

硬币找零&&爬楼梯&&猴子摘香蕉

假设有几种硬币,如1、3、5,并且数量无限。请找出能够组成某个数目的找零所使用最少的硬币数。

#include”CoinProblem.h”

#include

intcountNum=MAX;

voidCoinProblem(int*coin,intLength,intValue,intcount){

if(Value==0){

if(countNum>count){

countNum=count;

}

return;

}

for(inti=0;i

if(Value>=coin[i]){

CoinProblem(coin,Length,Value-coin[i],count+1);

}

}

}

#ifndefCOIN_PROBLEM_H

#defineCOIN_PROBLEM_H

#defineMAX65535

externintcountNum;

voidCoinProblem(int*coin,intLength,intValue,intcount);

#endif

#include”CoinProblem.h”

#include

intmain(){

intcoin[3]={1,3,5};

CoinProblem(coin,3,5,0);

std::cout<

}

这些问题都是一类问题,你猴子摘香蕉、硬币找零、爬楼梯等。

这类问题的共同点就是你要问题解决问题,也就是说你要恰好把问是不多不少地解决,不管你怎么摘香蕉,不管你一次

是摘几个,你得把香蕉摘完。你得恰好找别人那么钱,不能多也不能少。爬楼梯也一样啰。。反下是解决问题。

这个不像背包问题,因为背包是不一定能装满的,也就是结束条件是不确定的。

但是我们不要管是不是恰好,因为我们采用了梯归。因为递归的好处是把所有能考虑的问题都考虑了,包括恰好解决问题和

把问题所要求的多,或者少。。

if(Value==0){

if(countNum>count){

countNum=count;

}

return;

}

如上面的代码就是专门用来限制结束条件的,只有当我们找的钱恰好是那么多是,我们才会计数。

于是我们可能通过自己的限定条件来限制要计数的情况。

特注意的是:

​由于我自己的疏忽,导致在以前写这些代码的时候出了些小问题,以前我是这样写的

voidCoinProblem(int*coin,intLength,intValue,intcount){

if(Value==0){

if(countNum>count){

countNum=count;

}

return;

}

for(inti=0;i

if(Value>=coin[i]){

CoinProblem(coin,Length,Value-coin[i],++count);

}

}

}

看代码中红色的部分,这里成了++count,这里是改变了count的值,我这意思是改变了在这一次递归运算中的所有count的值,也就是说,i=0时

如count=2,同时也符合条件,也就是说进入那个条件判断语句,于是用++count时会发现count变成了3,这确实是我们所期望的,但是

如果下一次“归”回来后,i=1时,那时发现count一开始就是3了。不再是我们期望的2了。

于是正确的写法应该是这样:

voidCoinProblem(int*coin,intLength,intValue,intcount){

if(Value==0){

if(countNum>count){

countNum=count;

}

return;

}

for(inti=0;i

if(Value>=coin[i]){

CoinProblem(coin,Length,Value-coin[i],count+1);

}

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189390.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 千百撸

    千百撸千百撸(黄网)

    2022年8月2日
    25
  • 大数据_02【大数据基础知识】「建议收藏」

    大数据_02【大数据基础知识】「建议收藏」大数据_02【大数据基础知识】01什么是服务器02服务器类型03存储磁盘(硬盘)01什么是服务器服务器:也称伺服器,是一种高性能计算机,提供计算服务的设备。服务器的构成包括处理器、硬盘、内存、系统总线等,和通用的计算机架构类似。由于服务器需要提供高可靠的服务,所以在处理能力、稳定性、可靠性、安全性、可扩展性、可管理性等方面要求较高。服务器和电脑功能都是一样的,也可以将服务器称之为电脑,只是服务器对稳定性与安全性以及处理器数据能力有更高要求。比如我们随时浏览一个网站,发现这个网站

    2022年6月1日
    35
  • Linux 网卡特性配置 ethtool 详解 网卡Offload

    Linux 网卡特性配置 ethtool 详解 网卡Offload网络中校验和比较 2015 年 10 月 14 日本文说明了网卡 IP 层 TCP 层 UDP 层的校验和功能 以及异同点 网卡校验和高级的网卡 e1000e 等千 M 网卡 的接收 发送的校验和的计算方法是 CRC32 Refs http www wireshark org docs wsug html chunked ChAdvChecksu htmlhttp www in

    2025年8月15日
    4
  • sql mysql创建 视图索引_SQLServer中在视图上使用索引(转载)「建议收藏」

    sql mysql创建 视图索引_SQLServer中在视图上使用索引(转载)「建议收藏」在SQLServer中,视图是一个保存的T-SQL查询。视图定义由SQLServer保存,以便它能够用作一个虚拟表来简化查询,并给基表增加另一层安全。但是,它并不占用数据库的任何空间。实际上,在你查询它之前,视图并不做任何事情。索引视图在SQLServer2000和2005中,你能够给视图增加索引。但是,如果视图只是一个保存在数据库中的查询定义,在运行前没有自己的数据,你如何给那个定义建立…

    2022年7月22日
    19
  • CTF流量分析常见题型(二)-USB流量

    CTF流量分析常见题型(二)-USB流量0x00前言在学习Wireshark常见使用时,对常见CTF流量分析题型和铁人三项流量分析题的部分问题进行了简单总结。由于篇幅过长,于是另起一篇总结常见流量包分析。包括USB流量包分析和一些其他流量包分析。0x01USB流量包分析USB流量指的是USB设备接口的流量,攻击者能够通过监听usb接口流量获取键盘敲击键、鼠标移动与点击、存储设备的铭文传输通信、USB无线网卡网络传输内容等等。在CTF中,USB流量分析主要以键盘和鼠标流量为主。1、键盘流量USB协议数据部分在LeftoverCapt

    2022年6月11日
    139
  • Springboot连接mysql数据库中文乱码[通俗易懂]

    Springboot连接mysql数据库中文乱码[通俗易懂]第一步:查看springboot->Setting按照我的设置就行了。第二步配置文件中的url**?**后边的按照和我的一样serverTimezone=GMT%2B8&characterEncoding=utf-8第三步查看数据库编码,字段编码,右键数据库查看属性。查看数据库查看字段右键表,选择设计表查看。我的就是这样能插入中文。…

    2022年6月25日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号