【算法概论】贪心算法:区间调动问题

2024-03-10 01:38

本文主要是介绍【算法概论】贪心算法:区间调动问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

区间调动问题 Interval Scheling

题目描述:

       Job j starts at sj and finishes at fj .
       Two jobs compatible if the intervals [si,fi) and [sj,fj) do not overlap.
       Goal:find maximum subset of mutually compatible jobs.

❗算法描述❗: 

       对于这个问题,使用贪心算法描述的话,有以下几种考虑:

       a) 每次选取开始时间最早的;

       b) 每次选取结束时间最早的;

       c) 每次选取用时最短的;

       d) 在可选工作中,每次选取与最小可选工作有重叠的部分。

       证明看这里?https://blog.csdn.net/luoweifu/article/details/18195607

       b)是正确的思路,因为:

       结束时间最早, 所以取相同数量的工作肯定它最早结束或至少不晚;如果后面还有工作,那么加入到结束最早算法的空间更大,因此就不会存在比它更多工作的可能。(这段话转自https://www.cnblogs.com/yjlblog/p/7506887.html,这个博主的空间真的超好看了?)

       so,代码的思路?

       ① Sort fi

       ② Select the first job

       ③ Pick the first job i such that si ≥ fj, where job j is the most recently selected job.

代码:

       贪心法 - 非递归版:

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;//存储区间信息
struct Val
{int start = 0;int finish = 0;
};bool comp(const Val &a, const Val &b);int main()
{int num;cout << "请输入区间个数:" << endl;cin >> num;vector<Val> vals(num);cout << "请输入各区间的起点坐标和终点坐标:" << endl;for (int i = 0; i < num; ++i){cin >> vals[i].start>> vals[i].finish;}//依据 val[i].finish 进行排序sort(vals.begin(), vals.end(), comp);/*检验排序的结果√for (int i = 0; i < num; ++i){cout << vals[i].start << vals[i].finish;}*/int temp = 0;						//存储已被选入的上一区间的终点for (int i = 0; i < num; ++i){//如果区间 vals[i] 与 被选入的上一区间 没有重叠if (vals[i].start >= temp){cout << vals[i].start << ' ' << vals[i].finish << endl;			//将区间 vals[i] 选入temp = vals[i].finish;			//更新 temp 的值}}return 0;
}bool comp(const Val &a, const Val &b)
{return a.finish < b.finish;
}

       这里用到了:

       ① 结构体:把区间的信息定义成结构体,然后再用vector数组,真的很方便!

       ② 承接上面vector,这里代码首先是要根据区间终点进行排序的,vector的排序很方便!见:关于C++中vector和set使用sort方法进行排序。

       贪心法 - 递归版:

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;//存储区间信息
struct Val
{int start = 0;int finish = 0;
};int num;
vector<Val> vals;bool comp(const Val &a, const Val &b);
void IS_Recursive(int i, int temp);int main()
{cout << "请输入区间个数:" << endl;cin >> num;cout << "请输入各区间的起点坐标和终点坐标:" << endl;for (int i = 0; i < num; ++i){int temp1, temp2;cin >> temp1 >> temp2;Val temp;temp.start = temp1;temp.finish = temp2;vals.push_back(temp);}//依据 val[i].finish 进行排序sort(vals.begin(), vals.end(), comp);int temp = 0; 			//存储已被选入的上一区间的终点IS_Recursive(0, temp);return 0;
}void IS_Recursive(int i, int temp)
{if (i == num){return;}else{//如果区间 vals[i] 与 被选入的上一区间 没有重叠if (vals[i].start >= temp){cout << vals[i].start << ' ' << vals[i].finish << endl;			//将区间 vals[i] 选入temp = vals[i].finish;			//更新 temp 的值}IS_Recursive(i + 1, temp);}
}bool comp(const Val &a, const Val &b)
{return a.finish < b.finish;
}

       动态规划的版本:

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;//存储区间信息
struct Val
{int start = 0;int finish = 0;
};bool comp(const Val &a, const Val &b);int main()
{int num;cout << "请输入区间个数:" << endl;cin >> num;vector<Val> vals(num);cout << "请输入各区间的起点坐标和终点坐标:" << endl;for (int i = 0; i < num; ++i){cin >> vals[i].start >> vals[i].finish;}//依据 val[i].finish 进行排序sort(vals.begin(), vals.end(), comp);//动态规划vector<int> dp(num);dp[0] = 1;for (int i = 1; i < num; ++i){int flag = 0;							// flag 用于标记一段区间之前是否有其无重叠的区间,有标记为1,无标记为0//查找区间在 vals[i] 前一个无重叠的区间for (int j = i - 1; j >= 0; --j){if (vals[j].finish <= vals[i].start){dp[i] = max(dp[j] + 1, dp[i - 1]);		// dp[j] + 1 表示 选择vals[i]区间,dp[i - 1] 表示 不选择vals[i]区间flag = 1;break;}}if (flag == 0){dp[i] = 1;				//如果第 i 区间之前没有不重叠的区间,则dp[i] = 1}}cout << dp[num - 1] << endl;return 0;
}bool comp(const Val &a, const Val &b)
{return a.finish < b.finish;
}

       动态规划的思想参考了:【动态规划-贪心】区间调度问题

这篇关于【算法概论】贪心算法:区间调动问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

解决java.util.RandomAccessSubList cannot be cast to java.util.ArrayList错误的问题

《解决java.util.RandomAccessSubListcannotbecasttojava.util.ArrayList错误的问题》当你尝试将RandomAccessSubList... 目录Java.util.RandomAccessSubList cannot be cast to java.