买花最少花费问题(java版带详细注释)

2024-03-25 16:10

本文主要是介绍买花最少花费问题(java版带详细注释),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

买花最少花费问题

问题描述

商店中每种商品都有标价。例如,一朵花的价格是 2 元。一个花瓶的价格是 5 元。为了吸引顾客,商店提供了一组优惠商品价。优惠商品是把一种或多种商品分成一组,并降价销售。例如,3 朵花的价格不是 6 元而是 5 元。2 个花瓶加 1 朵花的优惠价是 10 元。试设计一个算法,计算出某一顾客所购商品应付的最少费用。

对于给定欲购商品的价格和数量,以及优惠商品价,编程计算所购商品应付的最少费用。

算法分析与设计

最优子结构证明:

c o s t ( a , b , c , d , e ) cost(a,b,c,d,e) cost(a,b,c,d,e)表示购买商品组合 ( a , b , c , d , e ) (a,b,c,d,e) (a,b,c,d,e)需要的最少费, A [ K ] , B [ K ] , C [ K ] , D [ K ] , E [ k ] A[K],B[K],C[K],D[K],E[k] A[K],B[K],C[K],D[K],E[k]表示第k种优惠方案。 o f f e r ( m ) offer(m) offer(m)是第 m m m种优惠方案的价格,如果 c o s t ( a , b , c , d , e ) cost(a,b,c,d,e) cost(a,b,c,d,e)使用了第 m m m种优惠方案,则
c o s t ( a , b , c , d , e ) = c o s t ( a − A [ m ] , b − B [ m ] , c − C [ m ] , d − D [ m ] , e − E [ m ] ) + o f f e r ( m ) cost(a,b,c,d,e)=cost(a-A[m],b-B[m], c-C[m], d-D[m], e-E[m])+offer(m) cost(a,b,c,d,e)=cost(aA[m],bB[m],cC[m],dD[m],eE[m])+offer(m)
即该问题具有最优子结构性质。

代码说明

package edu.xjtu.work3_14;import java.util.Scanner;public class Main {// 商品编码的最大值private static final int MAXCODE = 999;// 优惠商品组合数private static final int SALECOMB = 99;// 商品种类private static final int KIND = 5; // 购买某种商品数量的最大值private static final int QUANTITY = 5;// 记录商品编码与商品种类的对应关系private static final int[] num = new int[MAXCODE + 1];// 记录不同种类商品的购买数量private static final int[] product = new int[KIND + 1];// offer[i][j]: 商品组合的优惠价(j=0);某种优惠组合中某种商品需要购买的数量(j>0)private static final int[][] offer = new int[SALECOMB + 1][KIND + 1];// 记录不同商品的购买数量和购买价格private static final Goods[] goods = new Goods[KIND + 1];// 记录本次购买的总花费private static final int[][][][][] cost = new int[QUANTITY + 1][QUANTITY + 1][QUANTITY + 1][QUANTITY + 1][QUANTITY + 1];private static int b;// 购买商品种类数private static int s;// 当前优惠组合数public static void main(String[] args) {// 读入数据readInput();// 动态规划求最优解comp(1);// 输出out();}/*** 动态规划求最优解** @param i 下标*/private static void comp(int i) {if (i > b) {minicost();return;}for (int j = 0; j <= goods[i].getSum(); j++) {product[i] = j;comp(i + 1);}}/*** 初始化数据*/private static void readInput() { // 初始化数据Scanner input = new Scanner(System.in);int i, j, n, p, t, code;for (i = 0; i < 100; i++)for (j = 0; j < 6; j++)offer[i][j] = 0;for (i = 0; i < 6; i++) {goods[i] = new Goods();goods[i].setSum(0);goods[i].setPrice(0);product[i] = 0;}b = input.nextInt(); // 购买商品种类数for (i = 1; i <= b; i++) {code = input.nextInt();goods[i].setSum(input.nextInt());goods[i].setPrice(input.nextInt());num[code] = i;}s = input.nextInt(); // 当前优惠组合数for (i = 1; i <= s; i++) {t = input.nextInt();for (j = 1; j <= t; j++) {n = input.nextInt();p = input.nextInt();offer[i][num[n]] = p;}offer[i][0] = input.nextInt();}}/*** 计算最小花费*/private static void minicost() {int i, j, k, m, n, p, minm;minm = 0;for (i = 1; i <= b; i++)minm += product[i] * goods[i].getPrice();for (p = 1; p <= s; p++) {i = product[1] - offer[p][1];j = product[2] - offer[p][2];k = product[3] - offer[p][3];m = product[4] - offer[p][4];n = product[5] - offer[p][5];if (i >= 0 && j >= 0 && k >= 0 && m >= 0 && n >= 0 && cost[i][j][k][m][n] + offer[p][0] < minm)minm = cost[i][j][k][m][n] + offer[p][0];}cost[product[1]][product[2]][product[3]][product[4]][product[5]] = minm;}/*** 输出*/private static void out() {System.out.println(cost[product[1]][product[2]][product[3]][product[4]][product[5]]);}
}
package edu.xjtu.work3_14;public class Goods {private int price;// 购买价格private int sum;// 购买数量public int getPrice() {return price;}public void setPrice(int price) {this.price = price;}public int getSum() {return sum;}public void setSum(int sum) {this.sum = sum;}
}

运行结果展示

image-20211211205142242.png

这篇关于买花最少花费问题(java版带详细注释)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/845530

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2