贪心算法-以高校教材管理系统为例

1.贪心算法介绍 

1.算法思路

贪心算法的基本思路是从问题的某一个初始解出发一步一步地进行,根据某个优化测度,每一 步都要确保能获得局部最优解。每一步只考虑一 个数据,其选取应该满足局部优化的条件。若下 一个数据和部分最优解连在一起不再是可行解时, 就不把该数据添加到部分解中,直到把所有数据枚举完,或者不能再添加算法停止。 

贪心算法一般按如下步骤进行: 

①建立数学模型来描述问题 。

②把求解的问题分成若干个子问题 。

③对每个子问题求解,得到子问题的局部最优解 。

④把子问题的解局部最优解合成原来解问题的一个解 。

贪心算法是一种对某些求最优解问题的更简单、更迅速的设计技术。贪心算法的特点是一步一步地进行,常以当前情况为基础根据某个优化测度作最优选择,而不考虑各种可能的整体情况,省去了为找最优解要穷尽所有可能而必须耗费的大量时间。贪心算法采用自顶向下,以迭代的方法做出相继的贪心选择,每做一次贪心选择,就将所求问题简化为一个规模更小的子问题,通过每一步贪心选择,可得到问题的一个最优解。虽然每一步上都要保证能获得局部最优解,但由此产生的全局解有时不一定是最优的,所以贪心算法不要回溯 。

2.代码介绍

// 定义一个方法来计算最优的教材分配方案private static void calculateOptimalTextbookAllocation(Scanner scanner, SchoolService schoolService, TextbookService textbookService) {// 获取所有学校的列表和所有教材的列表List<School> schools = schoolService.listAllSchools();List<Textbook> textbooks = textbookService.listAllTextbooks();// 创建一个映射,存储每个学校的需求Map<Integer, Integer> schoolDemand = new HashMap<>();for (School school : schools) {System.out.print("请输入学校ID " + school.getSchoolId() + " 的需求:");int demand = scanner.nextInt(); // 从用户那里获取需求schoolDemand.put(school.getSchoolId(), demand); // 存储需求到映射}// 创建一个映射,存储每种教材的数量Map<Integer, Integer> textbookQuantity = new HashMap<>();for (Textbook textbook : textbooks) {System.out.print("请输入教材ID " + textbook.getTextbookId() + " 的数量:");int quantity = scanner.nextInt(); // 从用户那里获取教材数量textbookQuantity.put(textbook.getTextbookId(), quantity); // 存储教材数量到映射}// 使用Java 8的Streams API对学校列表按照需求进行降序排序// 这里使用了方法引用School::getSchoolId代替lambda表达式schools.sort(Comparator.comparingInt(School::getSchoolId).reversed());// 创建一个映射,存储最终的教材分配结果Map<Integer, Integer> allocation = new HashMap<>();for (School school : schools) {int demand = schoolDemand.get(school.getSchoolId()); // 获取当前学校的需求for (Textbook textbook : textbooks) {int quantity = textbookQuantity.get(textbook.getTextbookId()); // 获取当前教材的数量// 如果教材数量和需求都大于0,则进行分配if (quantity > 0 && demand > 0) {int allocated = Math.min(demand, quantity); // 计算可以分配的数量// 更新分配结果映射,增加分配数量allocation.put(school.getSchoolId(), allocation.getOrDefault(school.getSchoolId(), 0) + allocated);// 从教材数量中减去已分配的数量textbookQuantity.put(textbook.getTextbookId(), quantity - allocated);// 减少学校的需求demand -= allocated;}}}// 打印最优教材分配方案System.out.println("最优教材分配方案:");for (School school : schools) {int allocated = allocation.getOrDefault(school.getSchoolId(), 0); // 获取学校分配到的教材数量System.out.println("学校ID:" + school.getSchoolId() + ",分配数量:" + allocated);}}

3.应用概括

使用的算法是一个简单的贪心算法,尝试为每个学校分配尽可能多的教材,直到满足学校的需求或教材用尽。学校根据需求从大到小排序,以确保需求量大的学校能够优先获得教材分配。教材分配过程是一个迭代过程,每次迭代中都会尝试为当前学校分配尽可能多的教材,直到需求被满足或教材用尽。这个过程一直持续,直到所有学校都得到了尽可能多的教材分配。 

算法流程:

1. 初始化阶段:通过服务接口获取所有学校和教材的列表,初始化存储学校需求和教材数量的数据结构。

2. 数据收集:通过控制台输入,收集每个学校的需求和每种教材的可用数量。

3. 排序操作:将学校列表按照需求从大到小排序,以便优先满足需求量较大的学校。

4. 分配过程:遍历排序后学校的列表,对每所学校尝试分配教材,直到学校需求得到满足或教材用尽。

5. 更新状态:在分配过程中,更新已分配教材的数量和学校剩余需求。

6. 输出结果:打印最终的教材分配方案。

 代码实现:

 使用 `Scanner` 从控制台读取用户输入,获取学校的需求和教材的数量。

 使用 `HashMap` 存储学校需求和教材数量,便于快速访问和更新。

 使用 `List` 存储学校对象,并利用 `Collections.sort()` 方法进行排序。

 通过两层嵌套循环实现分配逻辑:外层循环遍历学校,内层循环遍历教材。

 数据结构:

 `List<School>` 和 `List<Textbook>`:存储学校和教材对象的列表,便于进行排序和遍历。

 `Map<Integer, Integer>`:存储学校需求和教材数量,键为学校ID或教材ID,值为需求或数量。这种映射提供了快速查找和更新的能力。

 `Comparator.comparingInt`:用于自定义排序逻辑,这里用于根据学校的需求进行排序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/42798.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pix4Dmapper:无人机测绘的革命性工具

在现代测绘和地理信息系统&#xff08;GIS&#xff09;领域&#xff0c;Pix4Dmapper无疑是一款革命性的工具。作为一名长期使用这款软件的用户&#xff0c;我深深感受到它在工作中的重要性和便利性。Pix4Dmapper不仅仅是一款软件&#xff0c;更是测绘工作者的得力助手&#xff…

285个地级市出口产品质量及技术复杂度(2011-2021年)

出口产品质量与技术复杂度&#xff1a;衡量国家竞争力的关键指标 出口产品质量是衡量国内企业生产的产品在国际市场上竞争力的重要标准。它不仅要求产品符合国际标准和目标市场的法律法规&#xff0c;而且需要保证产品质量的稳定性和可靠性。而出口技术复杂度则进一步体现了一…

新一代信息技术及应用

关于云计算的描述不正确的是&#xff08; &#xff09;。 A 云计算可以通过网络连接&#xff0c;用户通过网络接入“云”中并获得有关的服务&#xff0c;“云”内节点之间也通过内部的网络相连 B 云计算可以快速、按需、弹性服务&#xff0c;用户可以按照实际需求迅速获取或释放…

[Python学习篇] Python面向对象——类

面向对象是什么&#xff1f; 面向对象&#xff08;Object-Oriented Programming&#xff0c;简称OOP&#xff09;是一种编程范式&#xff0c;它使用“对象”来设计应用程序和计算机程序。OOP的核心概念包括类&#xff08;Class&#xff09;、对象&#xff08;Object&#xff09…

批量下载手机中APP程序中文件

需求 利用 adb pull 下载手机中app的某目录 adb pull 命令本身不支持直接下载整个目录&#xff08;文件夹&#xff09;及其所有子目录和文件作为一个单一的操作。但是&#xff0c;可以通过一些方法来间接实现这一目的。 方法 1. 首先将要下载的目录进行 tar 打包 # 在 And…

Python面试题:Python 中的 `property` 函数有什么用?

在 Python 中&#xff0c;property 函数用于创建和管理类中的属性。它允许你将方法转换为属性&#xff0c;这样你可以像访问变量一样访问这些方法。这对于控制属性的访问和修改非常有用&#xff0c;因为它允许你在属性访问时执行额外的逻辑&#xff08;如验证或计算&#xff09…

光通信领域常见的会议和期刊总结

在高速光通信小组待了一年&#xff0c;对我们领域主要的会议和期刊也有了一定的了解&#xff0c;所以总结一下我们可以投的期刊或会议有哪些。会议一般有OFC、ECOC、CLEO、OECC、ACP等&#xff0c;期刊则有OE、OL、PTL、JLT、PJ、AO、JOSA等&#xff0c;下面简单介绍一下。 先…

【atcoder】习题——位元枚举

题意&#xff1a;求i&M的popcount的和&#xff0c;i属于0……N 主要思路还是变加为乘。 举个例子N22&#xff0c;即10110 假设M的第3位是1&#xff0c;分析N中&#xff1a; 00110 00111 00100 00101 发现其实等价于 0010 0011 0000 0001 也就是左边第4位和第5…

算法学习笔记(8.1)-动态规划入门

目录 问题特性&#xff1a; 最优子结构&#xff1a; 代码示例&#xff1a;&#xff08;动态规划最优子结构&#xff09; 上述最小代价爬楼梯的运行过程&#xff1a; 代码示例&#xff1a; 无后效性&#xff1a; 解析&#xff1a; 具体过程图示如下&#xff1a; 具体的…

如何为IP申请SSL证书

目录 以下是如何轻松为IP地址申请SSL证书的详细步骤&#xff1a; 申请IP证书的基本条件&#xff1a; 申请IP SSL证书的方式&#xff1a; 确保网络通信安全的核心要素之一&#xff0c;是有效利用SSL证书来加密数据传输&#xff0c;特别是对于那些直接通过IP地址访问的资源。I…

使用 Azure DevOps Pipelines 生成 .NET Core WebJob 控制台应用 CI/CD

Web 应用程序通常需要作为后台任务运行的进程&#xff0c;并在特定时间间隔进行计划或在事件中触发。它们不需要花哨的 IO 接口&#xff0c;因为重点是过程而不是输出。Azure WebJobs 提供了出色的支持&#xff0c;通常在云环境中通过 Web 控制台应用程序来实现此目的。WebJob …

企业数字化转型中的低代码开发平台应用:释放创新潜能

随着信息技术的飞速发展&#xff0c;企业数字化转型已成为行业趋势。在这场转型浪潮中&#xff0c;低代码开发平台以其独特的优势&#xff0c;成为众多企业实现快速迭代、高效创新的得力助手。本文将深入探讨低代码开发平台在企业数字化转型中的应用&#xff0c;以及如何帮助企…

Mac平台虚拟机 Parallels Desktop v19.4.1,支持M1/M2/M3芯片组

Parallels Desktop for Mac是功能强大灵活度高的虚拟化方案&#xff0c;无需重启即可在同一台电脑上随时访问Windows和Mac两个系统上的众多应用程序。从仅限于PC的游戏到生产力软件&#xff0c;Parallels Desktop都能帮您实现便捷使用。Parallels Desktop 是一款专业的Mac虚拟机…

Docker搭建kafka+zookeeper以及Springboot集成kafka快速入门

参考文章 【Docker安装部署KafkaZookeeper详细教程】_linux arm docker安装kafka-CSDN博客 Docker搭建kafkazookeeper 打开我们的docker的镜像源配置 vim /etc/docker/daemon.json 配置 { "registry-mirrors": ["https://widlhm9p.mirror.aliyuncs.com"…

vue父子组件通信实现模糊搜索功能

我遇到的问题&#xff1a; 我的搜索框在父页面&#xff0c;静态数据都在子页面。怎么实现模糊查询数据&#xff1f; 昨天的尝试&#xff1a;先把搜索的内容数据存到session里&#xff0c;然后从session里拿&#xff0c; 结果&#xff1a;存是存进去了&#xff0c;却拿不到。应…

Django学习收尾

启动项目命令 python manage.py runserver 文件上传功能实现 title "Form上传"if request.method "GET":form UpForm()return render(request, upload_form.html, {"form": form, "title": title})form UpForm(datarequest.POS…

Java对象创建究竟是在栈上还是堆上??

在 Java 中&#xff0c;对象的创建通常情况下是在堆上。 基本数据类型&#xff08;如 byte、short、int、long、float、double、char&#xff09;在方法内声明时&#xff0c;其值会存储在栈上。除了基本数据类型之外的所有对象&#xff0c;都是由 Java 虚拟机&#xff08;JVM&…

python入门基础知识·二

""" # Python介绍 # Python注释 # 单行注释&#xff1a; # # 多行注释&#xff1a; r """""" # Python输出和输入 # print: 输出 # input: 输入 ①会让程序暂停&#xff0c;②得到的是字符串内容 int(&…

Linux Mac 安装Higress 平替 Spring Cloud Gateway

Linux Mac 安装Higress 平替 Spring Cloud Gateway Higress是什么?传统网关分类Higress定位下载安装包执行安装命令执行脚本 安装成功打开管理界面使用方法configure.shreset.shstartup.shshutdown.shstatus.shlogs.sh Higress官网 Higress是什么? Higress是基于阿里内部的…

Vue指令详解与实操运用 - 编程魔法

在Vue.js的世界里&#xff0c;指令就像是一位魔法师&#xff0c;它们能够赋予HTML元素以生命&#xff0c;让网页与用户互动起来。今天&#xff0c;我们就来揭开这些指令的神秘面纱&#xff0c;看看它们是如何在我们的日常开发中发挥作用的。 1. v-text 和 v-html - 文字与内容的…