当前位置: 首页 > news >正文

(算法)硬币问题

问题:有1元,5元,10元,50元,100元,500元的硬币各有C1,C5,C10.C50,C100,C500个。

           现在要用这些硬币来支付A元,最小需要多少枚硬币?

该题使用递归算法,利用局部最优解来推导全局最优解。

import java.util.Scanner;import static java.lang.Math.min;public class coin {static int[] cnts=new int[6];static int[] coins={1,5,10,50,100,500}; //硬币面额大小public static void main(String[] args) {Scanner sc=new Scanner(System.in);System.out.println("请输出每个硬币的个数");for (int i = 0; i < 6; i++) {       //输出每个硬币各有多少个cnts[i]=sc.nextInt();}System.out.println("请输出总金额");int A=sc.nextInt();             //输出金额int res=f(A,5);         //最开始由最大硬币面额500开始System.out.println(res);}static int f(int A,int cur){if(A<=0)return 0;if(cur==0)return A;int coinValue=coins[cur];int x=A/coinValue;          //该金额有多少个int cnt=cnts[cur];int t=min(x,cnt);       //return t+f(A-t*coinValue,cur-1);}
}

http://www.lryc.cn/news/399478.html

相关文章:

  • 如何隐藏 Ubuntu 顶部状态栏
  • 【C++】入门基础(引用、inline、nullptr)
  • 24/07/10数据结构(5.1213)链表OJ
  • C++ 入门基础:开启编程之旅
  • 据传 OpenAI秘密研发“Strawberry”项目
  • 简单的SQL字符型注入
  • HttpClient调用SpringBoot项目的文件上传接口实现文件上传
  • [leetcode]kth-smallest-element-in-a-sorted-matrix 有序矩阵中第k小元素
  • 【经典面试题】是否形成有环链表
  • Flask 用 Redis 缓存键值对-实例
  • 我的世界1.21多种服务端开服教程,原版/Forge/Fabric/Paper/Mohist...,Minecraft开服教程
  • docker安装nginx并配置https
  • 永磁同步电机控制算法--基于 SVM 的无磁链环 DTC
  • 如何避免在 Docker 容器中遇到 MAC 地址冲突和 IP 地址冲突的问题
  • arm64架构下源码编译安装kafka —— 筑梦之路
  • LabVIEW前面板占满整个屏幕(转)
  • Promise.all、any、race和allSettled的相同点与不同点与应用场景
  • Ubuntu下如何设置程序include搜索路径及链接路径
  • FLinkCDC引起的生产事故(二)
  • 【产品经理】WMS多仓调拨转移说明
  • 每日一练:奇怪的TTL字段(python实现图片操作实战)
  • 【Java开发实训】day03——方法的注意事项
  • HarmonyOS NEXT:一次开发,多端部署
  • Bilibili Android一二面凉经(2024)
  • 数据库内核研发学习之路(一)
  • LSTM:深度学习中的时间序列处理大师
  • T113-i系统启动速度优化方案
  • ArcGis将同一图层的多个面要素合并为一个面要素
  • 微软Win11 24H2七月更新补丁KB5040435发布!附下载
  • iOS 开发中不常见的专业术语