`
guanxi
  • 浏览: 41720 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

最简单的动态规划找零算法

 
阅读更多
package swTest;


/**
 * 动态规划学习
 * 1 找零问题 1,3,5 分的零钱,找11分钱,怎样个数最少
 * 采用动态规划的方法:
 *   @author samsung
 *   
 */
public class Test19 {
//	static    int[] change=new  int[]{1,3,5}; // 基础硬币数量
    static  int  conMum[] = new  int[99];  //对应的找零最小个数,保存最优状态
   
   static public void main(String[] arg){
	   conMum[0] = 0;
	   conMum[1] = 1;
	   conMum[2] = 2;
	   conMum[3] = 1;
	   conMum[4] = 2;
	   conMum[5] = 1;
	    //初始化数量
	 for(int i=6;i<99;i++){
		 concount(i); //规划求解
	 }
	 System.out.println(conMum[11]); //输出 11分就是 conMun[11];
   }
   
   /**
    * 函数 返回 面值 硬币的最小个数
    * @param con  面值
    * @param con1 硬币
    * @return
    */
   static void concount(int con){
		   conMum[con] = min(conMum[con-1]+1, conMum[con-3]+1, conMum[con-5]+1); 
		   //基本表达式就是这个
   }
   
   static int min(int a,int b,int c){
	    return Math.min(Math.min(a, b),c);
   }
}

 

分享到:
评论

相关推荐

    动态规划算法与贪心算法

    ### 动态规划算法与贪心算法 #### 最优化原理 最优化原理是解决多阶段决策问题的关键。这一原理最早由美国数学家R. Bellman等人于1951年提出,他们指出:一个最优策略的子策略对于它的初态和终态而言也必须是最优...

    易语言找零巧数算法

    在“易语言找零巧数算法”这个主题中,我们主要讨论的是如何利用易语言来实现一种高效的找零算法,尤其是在零售、餐饮等场景下,计算给定金额找零时最小硬币组合的问题。 找零巧数算法的核心在于优化硬币的组合,以...

    贪心算法找零问题代码

    这个贪心算法虽然简单且高效,但需要注意的是,它并不总是能找出全局最优解。例如,对于面值为{1, 3, 4}的硬币系统,找零6元时,贪心策略会给出两个3元硬币,而实际上只需要一个4元和两个1元硬币。因此,贪心算法在...

    易语言找零巧数算法源码.rar

    这个问题可以通过动态规划或者贪心算法来解决。在易语言中,我们可以使用循环和条件判断等基本结构来实现这样的算法。 首先,我们需要定义一个函数来处理找零问题。这个函数接收两个参数:一个是总金额,另一个是...

    贪心算法 找零钱

    在计算机科学与数学领域,贪心算法是一种解决问题的方法,它通过选择当前看起来最佳的选项来构建全局最优解。本篇文章将详细介绍如何使用贪心算法解决找零钱问题,并通过C语言实现。 #### 二、问题描述 假设我们有...

    算法设计与分析(贪婪/动态)

    总之,贪婪算法和动态规划是算法设计中的重要工具,它们提供了处理最优化问题的不同视角。理解并熟练掌握这两种方法,不仅能够提升你的编程能力,也是成为优秀算法工程师的基础。通过深入学习和实践,你将在面对各种...

    杭电贪心算法,动态规划,数论

    与贪心算法不同,动态规划是一种通过子问题的最优解来构建原问题最优解的方法。动态规划解决了贪心算法的局限性,通过记忆化搜索或表格填充的方式,避免了重复计算,并考虑到整体最优解。一个经典的动态规划问题实例...

    贪心算法与动态规划的比较.pdf

    首先用贪心算法快速找到一个可行解,然后利用动态规划对解进行优化,以确保得到全局最优解。这种策略在时间复杂度和解的优劣之间进行了权衡,力求在有限的资源内找到最佳解决方案。 最后,无论选择哪种策略,重要的...

    leetcode算法题主函数如何写-Dynamic-Programming-Note:动态规划算法学习心得(leetcode)

    动态规划算法主要有自上而下与自下而上两种方法,二者在时间和空间复杂度上并无区别,两种根据应用情况各有优劣,目前只碰到过找零问题,在代码的理解上和简单性上自下而上更胜一筹。 解题心路历程 原题: leetcode ...

    算法与程序设计:第4章 贪心算法.ppt

    3. 理解贪心算法与动态规划算法的差异 4. 通过应用范例学习贪心设计策略 贪心算法的应用: 1. 活动选择问题:选择活动的集合,使得所选择的活动的数量最大。 2. 活动分配问题:安排活动,使用最少的资源来安排所有...

    算法分析与设计实验报告

    动态规划算法通过自底向上的方式计算出每个可能金额的最小硬币组合,从而得到全局最优解。 伪造硬币问题则是一个典型的概率论和统计学应用问题。在这个问题中,我们假设有一堆硬币,其中一部分是伪造的,重量与真实...

    VB例程-找零助手

    找零算法是计算找回零钱的关键,通常会涉及穷举法或动态规划。在这个例子中,由于面额相对固定(例如:100元、50元、20元、10元、5元、1元等),算法可能采用穷举法,遍历所有可能的纸币组合,使得组合的总值等于...

    贪心算法 找零钱问题

    贪心算法是一种简单直观的算法设计策略,在很多优化问题中被广泛应用。它的基本思想是在每一步选择中都采取当前状态下最好或最优(即最有利)的选择策略,从而希望导致结果是全局最优解的方法。在本篇文章中,我们将...

    贪婪算法,MATLAB

    贪婪算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是...因此,在设计算法时,需要根据问题特性谨慎选择是否采用贪婪策略,并结合其他算法,如动态规划,以提高解的质量。

    运用贪心算法求解找零钱问题

    贪心算法在找零钱问题中的应用展示了其简单而高效的特点。尽管这种方法不能保证在所有情况下都能找到最少硬币数的解(比如,找93分的零钱,用2个25分和1个13分的硬币是更好的解,而非3个25分、1个10分和3个1分),但...

    03.动态规划1

    动态规划是一种解决问题的方法,特别适用于解决那些具有重叠子问题和最优子结构的复杂问题。在动态规划中,我们不是通过递归的方式反复求解相同的子问题,而是将子问题的解存储起来,避免了重复计算,从而提高了算法...

    五大常用算法总结 (1),算法数据结构

    本文将对五种常用算法进行总结,分别是贪婪算法、动态规划、分治算法、回溯算法和分支限界算法。 1. **贪婪算法**: 贪婪算法是一种基于局部最优选择的策略,它在每一步都选择当前看起来最好的解决方案。然而,...

    贪心算法——最少硬币找钱

    ### 贪心算法在最少硬币找零问题中的应用 #### 一、问题背景及定义 在实际生活中,我们经常遇到需要找零的情况。如何用最少数量的硬币完成找零?这个问题不仅关乎日常生活中的便利性,也是计算机科学领域内一个...

    《算法分析与设计》 实验指导

    这种算法简单高效,但在某些情况下可能无法得到最优解,如找零问题可能存在多种组合,贪心策略不一定能给出最小硬币数量。 **动态规划**是解决具有重叠子问题和最优子结构的问题的有效方法。在“0-1”背包问题中,...

Global site tag (gtag.js) - Google Analytics