贪心算法的C/C++程序,用于找到最少硬币数量

贪心算法的c/c++程序,用于找到最少硬币数量

贪心算法是一种用于寻找给定问题的最优解决方案的算法。贪婪算法的工作原理是找到每个部分的局部最优解(问题的一部分的最优解),因此表明可以找到全局最优解。

在这个问题中,我们将使用贪婪算法算法来找到可以组成给定总和的最小硬币/纸币数量。 为此,我们将考虑所有有效的硬币或纸币,即面额为 { 1, 2, 5, 10, 20, 50 , 100, 200 , 500 ,2000 }。我们需要返回需要补足总和的硬币/纸币的数量。

让我们举几个例子来更好地理解上下文 –

示例 1 –

Input : 1231Output : 7

说明 – 我们需要两张 500 卢比纸币、两张 100 卢比纸币、一张 20 卢比纸币、一张 10 卢比纸币和一张 Re 1 硬币。总计为 2+2+1+1+1 = 7

立即学习“C++免费学习笔记(深入)”;

示例 2 –

Input : 2150Output : 3

说明 – 我们需要一张 2000 卢比纸币、一张 100 卢比纸币和一张 50 卢比纸币。

为了使用贪心算法解决此问题,我们将找到最大面额的纸币可以使用。然后我们将从总和中减去最大面额,并再次执行相同的过程,直到总和为零。

算法

Input: sum,Initialise the coins = 0Step 1: Find the largest denomination that can be used i.e. smaller than sum.Step 2: Add denomination two coins and subtract it from the SumStep 3: Repeat step 2 until the sum becomes 0.Step 4: Print each value in coins.

示例

 实时演示

#include using namespace std;int notes[] = { 1, 2, 5, 10, 20, 50, 100, 200, 500, 2000 };int n = sizeof(notes) / sizeof(notes[0]);void minchange(int sum){   vector coins;   for (int i = n - 1; i >= 0; i--) {      while (sum >= notes[i]) {         sum -= notes[i];         coins.push_back(notes[i]);      }   }   for (int i = 0; i < coins.size(); i++)      cout << coins[i] << "t";}int main(){   int n = 3253;   cout << "The minimum number of coins/notes that sum up " << n << " is t ";   minchange(n);   return 0;}

输出

The minimum number of coins/notes that sum up 3253 is2000 500 500 200 50 2 1

以上就是贪心算法的C/C++程序,用于找到最少硬币数量的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445522.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:35:26
下一篇 2025年12月17日 22:35:34

相关推荐

  • 一些关于C/C++三元运算符的有趣观察

    我们知道三元运算符是代替 if..else 子句实现的。它由 ?: 表示。 ‘?’符号相当于 if 部分,’:’ 相当于 else 部分。以下 3 个程序解释了三元运算符情况下的一些有趣的观察结果。 以下程序能够编译,没有任何错误。三元表达式的返回类型…

    2025年12月17日
    000
  • 在C/C++中,strcmp()函数用于比较两个字符串

    The function strcmp() is a built-in library function and it is declared in “string.h” header file. This function is used to compare the string argumen…

    2025年12月17日
    000
  • 如何使用C/C++检查输入是否为整数?

    在这里,我们将看到如何检查给定的输入是整数字符串还是普通字符串。整数字符串将包含在0-9范围内的所有字符。解决方案非常简单,我们将逐个检查每个字符,然后检查它是否是数字。如果是数字,则指向下一个字符,否则返回false值。 示例 #include using namespace std;bool i…

    2025年12月17日
    000
  • 在C/C++中,“dereferencing”一个指针是什么意思?

    解引用用于访问或操作指针指向的内存位置中包含的数据。 *(星号)与指针变量一起使用,当解引用指针变量时,它指的是被指向的变量,所以这称为指针的解引用。 int main() { int a = 7, b ; int *p; // Un-initialized Pointer p = &a; …

    2025年12月17日
    000
  • 使用分支限界法在C/C++中实现0/1背包问题

    这个想法是为了实现贪婪方法为分数背包问题提供最佳解决方案这一事实。 为了检查特定节点是否可以为我们提供更好的解决方案,我们计算最佳解决方案(通过节点)实施贪心方法。如果贪心法本身计算出的解比目前为止最好的解要多,那么我们就无法通过节点获得更好的解。 完整的算法如下 – 根据每单位重量的价…

    2025年12月17日
    000
  • 在C/C++中,4维数组

    一个4维数组是由3维数组组成的数组。 算法 Begin. Declare the variables. Declare the array elements. Take the no of elements as input. Take the elements as input. Print th…

    2025年12月17日
    000
  • 在C/C++中的线程函数

    在本教程中,我们将讨论一个程序来理解 C/C++ 中的线程函数。 线程函数允许用户同时实现并发函数,这些函数可以相互依赖用于执行或独立。 示例 #include #include #include void* func(void* arg){ //detaching the current thre…

    2025年12月17日
    000
  • 如何在C/C++中使用枚举?

    枚举是C语言中的用户定义数据类型。它用于给整数常量赋予名称,使程序易于阅读和维护。关键字“enum”用于声明一个枚举。 以下是C语言中枚举的语法: enum enum_name{const1, const2, ……. }; The enum keyword is also used to d…

    2025年12月17日
    000
  • C/C++程序:计算一个整数中设置的位数?

    对设置的位进行计数意味着对给定整数进行 1 的计数。为此,我们有多种可以应用的解决方案。对于这种情况,我们有一个二进制数(整数的二进制表示),为此我们必须计算字符串中 1 的数量。 要计算 1 的数量,我们将获取字符串,遍历每个元素并统计字符串中所有1的个数。例如,如果我们输入 17,则输出将为 2…

    2025年12月17日
    000
  • 如何实现C#中的贪心算法

    如何实现C#中的贪心算法 贪心算法(Greedy algorithm)是一种常用的问题求解方法,它每次选择当前最优的解决方案,希望能够获得全局最优解。在C#中,我们可以利用贪心算法解决许多实际问题。 本文将介绍如何在C#中实现贪心算法,并提供具体的代码示例。 一、贪心算法的基本原理 贪心算法的基本思…

    2025年12月17日
    000
  • Python中如何实现贪心算法?

    贪心算法在python中通过排序和选择实现。1.排序活动以结束时间为依据。2.选择结束时间最早且不重叠的活动。该方法适用于活动选择问题,但在复杂背包问题中可能无法达到全局最优解。 贪心算法是一种解决优化问题的策略,它在每一步都选择当前看起来最优的选择,以期望达到全局最优解。让我们深入探讨一下在Pyt…

    2025年12月14日
    000
  • 如何使用Python实现贪心算法?

    如何使用Python实现贪心算法? 贪心算法(Greedy Algorithm)是一种简单而有效的算法,适用于解决那些具有最优子结构性质的问题。它在每一步选择中都采取当前状态下最优的选择,希望能够找到全局最优解。在本篇文章中,将介绍如何使用Python实现贪心算法,并附带具体的代码示例。 一、贪心算…

    2025年12月13日
    000
  • Java 函数中如何应用贪心算法优化?

    %ignore_a_1%是一种优化问题中的决策过程,在每个子问题中做出当前最优选择,通过分解问题、做出贪心选择和设置终止条件,可在 java 函数中应用它。实战案例:背包问题,采用动态规划算法求解,通过自顶向下的决策过程,在每次迭代中做出贪心选择,并存储子问题的解,最终返回最大价值的解。 Java …

    2025年11月27日 java
    000
  • 什么是贪心算法?贪心算法的适用条件

    贪心算法的核心思想是在每一步选择中都采取当前状态下最优的决策,期望通过一系列局部最优解最终得到全局最优解,其与动态规划的最大区别在于贪心算法不具备回溯机制,决策一旦做出不可更改,而动态规划通过保存子问题的解并综合考虑所有可能路径来保证全局最优;判断贪心算法是否适用的关键是问题必须同时满足贪心选择性质…

    2025年11月19日
    000
  • 利用K最近邻算法进行基本面部识别配合面部标志

    ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜ 面部识别是一种利用计算机视觉技术进行人脸识别和验证的过程。这项技术已经被广泛应用于各种应用程序,如安全系统、图像搜索和社交媒体。其中,基于面部标志和K最近邻算法的面部识别方法简单而有效。该方法通…

    2025年11月7日 科技
    000

发表回复

登录后才能评论
关注微信