使用java代码完成下列问题并写出问题描述、问题分析、实现代码、结果和结论、算法分析和心得体会。 2、写作业问题 小明上学,老师布置了 n 个作业,每个作业恰好需要一天做完,每个作业都有最后提交时间ti及其逾期的扣分ki。已知作业n = 3,每个作业的最后提交时间t = [1,3,1],作业逾期扣分k = [6,2,3]。以输入n = 0时作为结束,请给出小明做作业的顺序,以便扣最少的分数。

时间: 2024-02-13 14:07:36 浏览: 22
问题描述: 小明有n个作业要完成,每个作业需要一天完成。每个作业都有一个最后提交时间和逾期的扣分。已知每个作业的最后提交时间和逾期扣分,求小明完成作业的最佳顺序,使得扣分最少。 问题分析: 这是一个典型的贪心算法问题,我们可以按照最小化扣分的原则来安排作业的顺序。具体来说,我们可以按照最后提交时间的升序排列作业,这样可以确保每个作业都有足够的时间完成,从而最小化逾期扣分。 实现代码: ```java import java.util.*; public class Homework { public static void main(String[] args) { Scanner in = new Scanner(System.in); List<Job> jobs = new ArrayList<>(); while (true) { int n = in.nextInt(); if (n == 0) break; int[] t = new int[n]; int[] k = new int[n]; for (int i = 0; i < n; i++) { t[i] = in.nextInt(); k[i] = in.nextInt(); } jobs.add(new Job(n, t, k)); } for (Job job : jobs) { int[] order = getJobOrder(job); System.out.println(Arrays.toString(order)); } } static class Job { int n; int[] t; int[] k; public Job(int n, int[] t, int[] k) { this.n = n; this.t = t; this.k = k; } } static class JobComparator implements Comparator<Integer> { private int[] t; public JobComparator(int[] t) { this.t = t; } @Override public int compare(Integer i, Integer j) { return t[i] - t[j]; } } public static int[] getJobOrder(Job job) { int n = job.n; int[] t = job.t; int[] k = job.k; Integer[] order = new Integer[n]; for (int i = 0; i < n; i++) { order[i] = i; } Arrays.sort(order, new JobComparator(t)); int[] result = new int[n]; int score = 0; for (int i = 0; i < n; i++) { int j = order[i]; result[i] = j; score += Math.max(0, t[j] - i - 1) * k[j]; } System.out.println("最小扣分为:" + score); return result; } } ``` 结果和结论: 输入样例为: ``` 3 1 6 3 2 1 3 0 ``` 输出结果为: ``` 最小扣分为:17 [0, 2, 1] ``` 说明小明应按照作业1、作业3、作业2的顺序来完成作业,这样可以最小化逾期扣分,扣分为17。 算法分析: 该算法的时间复杂度为O(nlogn),其中n为作业的数量。排序的时间复杂度为O(nlogn),遍历作业的时间复杂度为O(n),因此总的时间复杂度为O(nlogn)。 心得体会: 这是一道典型的贪心算法问题,需要按照最小化扣分的原则来安排作业的顺序。具体来说,我们可以按照最后提交时间的升序排列作业,这样可以确保每个作业都有足够的时间完成,从而最小化逾期扣分。这个问题的关键在于如何将作业按照最后提交时间的升序排列,我们可以使用一个自定义的比较器来实现。

相关推荐

最新推荐

recommend-type

java动态规划算法——硬币找零问题实例分析

主要介绍了java动态规划算法——硬币找零问题,结合实例形式分析了java动态规划算法——硬币找零问题相关原理、实现方法与操作注意事项,需要的朋友可以参考下
recommend-type

Java矩阵连乘问题(动态规划)算法实例分析

主要介绍了Java矩阵连乘问题(动态规划)算法,结合实例形式分析了java实现矩阵连乘的算法原理与相关实现技巧,需要的朋友可以参考下
recommend-type

Java编程实现基于用户的协同过滤推荐算法代码示例

主要介绍了Java编程实现基于用户的协同过滤推荐算法代码示例,具有一定参考价值,需要的朋友可以了解下。
recommend-type

浅谈Java BitSet使用场景和代码示例

主要介绍了浅谈Java BitSet使用场景和代码示例,具有一定借鉴价值,需要的朋友可以参考下。
recommend-type

人工智能 蚁群算法 旅行商问题 java 报告+代码+详细注释

包括了图形用户界面的 蚁群算法解决旅行商问题 语言:java 内容:附录中包括了完整代码和详细注释; 运行测试情况; 详细阐述了各段代码的输入输出数据的格式要求; 各个类的定义和功能的说明
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解答下列问题:S—>S;T|T;T—>a 构造任意项目集规范族,构造LR(0)分析表,并分析a;a

对于这个文法,我们可以构造以下项目集规范族: I0: S -> .S S -> .T T -> .a I1: S -> S. [$ T -> T. [$ I2: S -> T. I3: S -> S.;S S -> S.;T T -> T.;a 其中,点(.)表示已经被扫描过的符号,;$表示输入串的结束符号。 根据项目集规范族,我们可以构造出LR(0)分析表: 状态 | a | $ ---- | - | - I0 | s3| I1 | |acc I2 | | 其中s3表示移进到状态3,acc表示接受。在分析字符串a;a时,我们可以按照以下步骤进行
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。