C++超详细讲解贪心策略的设计及解决会场安排问题
作者:对象new不出来 发布时间:2022-07-26 12:08:04
问题描述
设有n个会议的集合C={1,2,…,n},其中每个会议都要求使用同一个资源(如会议室),而在同一时间内只能有一个会议使用该资源。每个会议i都有要求使用该资源的起始时间bi和结束时间ei,且bi < ei 。如果选择了会议i使用会议室,则它在半开区间[bi, ei)内占用该资源。如果[bi, ei)与[bj , ej)不相交,则称会议i与会议j是相容的。会场安排问题要求在所给的会议集合中选出最大的相容活动子集,也即尽可能地选择更多的会议来使用资源。
贪心策略
1、选择最早开始时间且不与已安排会议重叠的会议
2、选择使用时间最短且不与已安排会议重叠的会议
3、选择具有最早结束时间且不与已安排会议重叠的会议
这里我选取第三种方法
算法设计
设有11个会议等待安排,用贪心法找出满足目标要求的会议集合。这些会议按结束时间的非减序排列如表所示
11个会议按结束时间的非减序排列表:
代码实现
#include <iostream>
#include "会场安排.h"
#define n 11
struct meeting{
int B;//开始时间
int E;//结束时间
};
using namespace std;
int main()
{
meeting M[n] = { {8,11}, {8,12}, {2,13}, {12,14}, {1,4},
{3,5}, {0,6}, {5,7}, {3,8}, {5,9}, {6,10} };
for(int i=0;i<n;i++)
for(int j=0;j<n-i-1;j++)
if (M[j].E > M[j + 1].E) {
meeting T;
T = M[j]; M[j]= M[j+ 1]; M[j+1]= T;
}
int allowedTime = 0;
for (int i = 0,j=0; i < n; i++) {
if (M[i].B > allowedTime) {
j++;
cout << "安排的第"<<j<<"个会议号是 " << i+1 <<" 此会议开始时间为:" << M[i].B
<<" 此会议结束时间是:" << M[i].E << endl;
allowedTime = M[i].E;
}
}
}
选择结构体
定义meeting结构体,只设置会议开始时间B和结束时间E即可。
随机输入会议
n 为11
meeting M[n] = { {8,11}, {8,12}, {2,13}, {12,14}, {1,4},
{3,5}, {0,6}, {5,7}, {3,8}, {5,9}, {6,10} };
按结束时间排序
冒泡排序实现即可:
for(int i=0;i<n;i++)
for(int j=0;j<n-i-1;j++) if (M[j].E > M[j + 1].E)
{
meeting T; T = M[j]; M[j]= M[j+ 1]; M[j+1]= T;
}
这里的中间变量必须设置为 meeting 类型,以便于将会议的所有属性都交换
最终会议确定
int allowedTime = 0;
for (int i = 0,j=0; i < n; i++) {
if (M[i].B > allowedTime) {
j++;
cout << "安排的第"<<j<<"个会议号是 " << i+1 <<" 此会议开始时间为:" << M[i].B
<<" 此会议结束时间是:" << M[i].E << endl;
allowedTime = M[i].E;
}
}
先将会议开始时间设置为0,只要把按结束时间升序排列的第一个大于0的开始时间加到第一个内容哦即可,随后将第一个会议的结束时间设置为allowedTime,产生下一个不与第一个会议时间冲突的会议;然后自己加点输出语句,美观的运行出来结果就好了。
结束语
这算是贪心法第一个案例,也是比较好理解的一个案例,希望大家分析后都能有自己的收获,下篇博客再见,觉得好就鼓励鼓励博主吧
来源:https://blog.csdn.net/m0_58618795/article/details/124839807


猜你喜欢
- 一、说明Boost.MPI 提供了 MPI 标准(消息传递接口)的接口。该标准简化了并发执行任务的程序的开发。您可以使用线程或通过共享内存或
- 在EditText输入数字的时候,通常我们需要限制小数点前后位数。比如金额输入一般我们需要限制小数点后面最多2位。我们可以通过 TextWa
- 本文较为详细的分析了C#中sleep和wait的区别。分享给大家供大家参考。具体分析如下:sleep和wait都是使线程暂时停止执行的方法,
- 控制json序列化/反序列化1. @JsonIgnoreProperties的用法@JsonIgnoreProperties(value =
- 一、Synchronized的基本使用Synchronized是Java中解决并发问题的一种最常用的方法,也是最简单的一种方法。Synchr
- 里氏替换原则(LSP)定义:在任何父类出现的地方都可以用它的子类类替换,且不影响功能。解释说明:其实LSP是对开闭原则的一个扩展,在OO思想
- Java是一种强类型, 许多流行的编程语言都已经支持局部变量类型推断,如js,Python,C++等JDK10 可以使用var作为局部变量类
- 前言之前介绍了 Animatable 动画以及其 animateTo和 snapTo两个开启动画 api 的使用,实际上 Animatabl
- Mybatis @Select、foreachforeach属性属性描述item循环体中的具体对象。支持属性的点路径访问,如item.age
- 本文实例为大家分享了java数字转汉字工具类的具体代码,供大家参考,具体内容如下/** * Created by 33303 on 2017
- 在 Spring Boot 中做权限管理,一般来说,主流的方案是 Spring Security ,但是,仅仅从技术角度来说,也可以使用 S
- Android实现TextView超链接一共有五种方式:推荐第四种、第五种1. 直接在xml文件中配置autoLink属性(简单易用,效果单
- 四道Java基础题,你能对几道?一、==符的使用首先看一段比较有意思的代码Integer a = 1000,b=1000; Integer
- 前言兄弟们,刚刚又给seata社区修了一个BUG,有用户提了issue反应TransactionHook在某些情况下不会被调用:相关issu
- 基于Java的简单的企业员工管理系统,供大家参考,具体内容如下首先创建了一个员工类定义员工应有的属性:工号、姓名、性别、职位、年龄、工资、部
- 像javascript中有eval()来执行动态代码,c#中是没有的,于是自己动手丰衣足食,先来代码using System;using S
- 最近chatGPT也是非常的火爆,相信大家都看到了,现在提供一种Java调用chatGPT的方法,我们主要通过两个工具来实现,一就是http
- 简介Trie树,又称为前缀树或字典树,是一种有序树,用于保存关联数组,其中的键通常是字符串。与二叉查找树不同,键不是直接保存在节点中,而是由
- 相比于直线检测,直线拟合的最大特点是将所有数据只拟合出一条直线void fitLine( InputArray points, Output
- 用java实现的登录与注册页面,实现了客户端(浏览器)到服务器(Tomcat)再到后端(servlet程序)数据的交互。这里在注册页面加入了