news 2026/3/11 0:12:55

活动安排问题的贪心算法实践与代码解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
活动安排问题的贪心算法实践与代码解析

创作灵感

在算法领域,贪心算法以其 “局部最优推导全局最优” 的核心思想,成为解决资源调度类问题的经典思路。活动安排问题作为贪心算法的典型应用场景,能直观体现这一思想的价值。本文将从问题分析入手,拆解贪心策略的设计逻辑,结合完整代码实现,详解如何高效解决活动安排问题。

一、问题背景与核心需求

活动安排问题的核心场景是:给定若干个共享同一资源(如会议室、体育场)的活动,每个活动有唯一的开始时间和结束时间,资源同一时间仅能被一个活动占用。我们需要找到一种安排方式,使得能被成功安排的活动数量最多,最大化资源利用率。

以本文实现的场景为例:假设有 10 个活动申请使用同一场地,场地开放时间为 0 时至 24 时,每个活动随机生成开始时间s和结束时间fs < f),需通过算法筛选出最多可安排的活动数量,并输出每个活动的安排结果。

二、贪心策略的核心思路

解决活动安排问题的关键,是确定 “局部最优” 的选择标准:

  • 最优策略:优先选择结束时间最早的活动。这一选择能最大程度为后续活动腾出时间,是实现 “最多活动安排” 的核心逻辑。
  • 反证:若先选结束晚的活动,后续可选择的活动范围会大幅缩小,无法保证全局最优。

代码实现,详解如何高效解决活动安排问题。

三、完整代码实现与逐段解析

#include<cstdlib> #include<ctime> #include<iostream> using namespace std; const int N=10; // 活动总数 // 定义活动结构体,存储核心信息 struct activity{ int No; // 活动编号 int s; // 开始时间 int f; // 结束时间 int conti; // 持续时间 }; // 选择排序:按活动结束时间升序排列 void selectsort(activity a[]){ for(int i=0;i<N;i++){ for(int j=i+1;j<N;j++){ if(a[j].f < a[i].f){ // 核心:按结束时间升序 activity x = a[i]; a[i] = a[j]; a[j] = x; } } } } // 贪心算法核心:筛选可安排的活动 int greedy(activity a[]){ selectsort(a); // 先排序,保证贪心策略执行基础 int count=0; // 记录可安排活动数量 int time=0; // 场地最早可用时间(初始为场地开放时间) for(int i=0;i<N;i++){ // 核心条件:当前活动开始时间 ≥ 场地可用时间,无冲突 if(a[i].s >= time){ count++; time = a[i].f; // 更新场地可用时间为当前活动结束时间 cout<<"活动"<<a[i].No<<"要求占用"<<a[i].s<<"时至"<<a[i].f<<"时,可以安排,场地从"<<time<<"时开始空闲"<<endl; } else { cout<<"活动"<<a[i].No<<"要求占用"<<a[i].s<<"时至"<<a[i].f<<"时,与场地最早空闲时间"<<time<<"时冲突,不能安排"<<endl; } } return count; // 返回最多可安排活动数 } int main(){ srand((unsigned)time(NULL)); // 初始化随机数种子,保证每次运行结果不同 int begin=0,end=24; // 场地开放时间:0时-24时 cout<<"场地开放时间:"<<begin<<"时-"<<end<<"时"<<endl; activity a[N]; // 定义10个活动 // 随机生成每个活动的时间信息 for(int i=0;i<N;i++){ a[i].No = i; a[i].s = rand()%end; // 开始时间:0-23随机 // 结束时间:大于开始时间,且≤24 a[i].f = a[i].s + rand()%(end+1 - a[i].s); a[i].conti = a[i].f - a[i].s; cout<<"活动"<<a[i].No<<"要求占用"<<a[i].s<<"至"<<a[i].f<<"时"<<endl; } // 调用贪心算法,输出结果 cout<<"最多可安排"<<greedy(a)<<"个活动"<<endl; return 0; }
(1)数据结构定义

通过activity结构体封装每个活动的编号、开始时间、结束时间、持续时间,便于统一管理和排序操作,符合面向过程编程中 “数据聚合” 的设计思路。

(2)排序函数selectsort
  • 原代码中错误地按活动编号排序,此处修正为按结束时间升序排序 —— 这是贪心策略的核心前提。
  • 采用选择排序实现,逻辑简单直观,适合小规模数据(N=10)的排序需求;若活动数量增大,可替换为效率更高的快速排序。
(3)贪心核心函数greedy
  • 排序后遍历所有活动,通过time变量记录场地当前最早可用时间,初始值为场地开放时间(0 时)。
  • 核心判断条件a[i].s >= time:确保当前活动与已安排活动无时间冲突,满足条件则安排该活动,并更新time为当前活动的结束时间。
  • 实时输出每个活动的安排结果,便于直观验证算法逻辑,同时返回最终安排的活动总数。
(4)主函数main

六、总结

活动安排问题的核心是贪心算法 “局部最优” 策略的落地 —— 通过选择结束时间最早的活动,实现全局最多活动的安排。本文从问题分析到代码实现,修正了原代码的核心错误(排序逻辑),完善了随机数生成逻辑,同时拆解了每个模块的设计思路。

通过本次实践可深刻体会:贪心算法的关键在于 “最优子结构” 的识别(即局部最优能推导全局最优),而代码实现的细节(如排序依据、条件判断)直接决定算法是否有效。掌握这一思路后,可将其迁移到区间调度、任务选择等同类问题中,提升算法应用能力。

题——

  • 初始化随机数种子:取消原代码中rand的注释,保证每次运行生成不同的活动时间,模拟真实场景的随机性。
  • 随机生成活动时间:通过rand()函数控制开始时间范围为 0-23,结束时间大于开始时间且≤24,避免出现无效的时间区间。
  • 输出初始活动信息和最终安排结果,形成完整的流程闭环。
  • 拓展与优化方向

  • 排序优化:当活动数量 N 增大时,选择排序的 O (n²) 时间复杂度效率较低,可替换为sort函数(基于快速排序,O (n log n)),需为结构体重载比较规则。
  • 边界条件增强:可增加对活动结束时间超过场地关闭时间(24 时)的判断,直接标记为不可安排,进一步提升代码健壮性。
  • 带权活动扩展:若每个活动有不同的权重(如收益),需调整贪心策略为 “按单位时间收益排序”,或采用动态规划解法,满足更复杂的业务需求。
  • 可视化展示:结合图表库(如 Matplotlib)将活动时间轴可视化,更直观地展示安排结果。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/4 13:00:44

31、Linux网络服务与协议配置详解

Linux网络服务与协议配置详解 在当今的网络环境中,Linux系统凭借其强大的网络功能和高度的可定制性,在企业和数据中心中得到了广泛应用。本文将深入探讨Linux系统中NFS(网络文件系统)服务以及IPX和NCP文件系统的相关配置和使用。 NFS挂载选项详解 NFS是一种在网络中实现…

作者头像 李华
网站建设 2026/3/10 4:39:37

34、UUCP 配置与使用全解析

UUCP 配置与使用全解析 1. UUCP 连接与传输流程 UUCP(Unix-to-Unix Copy Program)在进行文件传输时,首先会进行握手阶段。在这个阶段,两个站点会维护成功连接的计数,并进行比较。若计数不匹配,握手就会失败,这一机制能有效防范冒名顶替者。 之后,两个 uucico 进程会…

作者头像 李华
网站建设 2026/3/10 17:41:24

45、C News系统配置与管理指南

C News系统配置与管理指南 在当今的信息时代,新闻组系统是信息传播和交流的重要平台之一。C News作为一款经典的新闻组服务器软件,其配置和管理对于确保新闻组的正常运行和信息的有效传播至关重要。本文将详细介绍C News系统的配置和管理要点,包括初始设置、关键文件的配置…

作者头像 李华
网站建设 2026/3/9 23:44:45

现代Python包管理工具效能对比:uv与pip深度评测

Python包管理在AI项目开发中扮演着至关重要的角色。随着ComfyUI-Manager这类大型AI项目的复杂度不断提升&#xff0c;传统的pip包管理方式已难以满足高效开发的需求。本文基于ComfyUI-Manager v3.38.3版本&#xff0c;深入剖析新一代包管理器uv与传统pip在实际项目中的性能表现…

作者头像 李华
网站建设 2026/3/4 14:20:43

Bark语音生成模型:从零到精通的完整实战指南

Bark语音生成模型&#xff1a;从零到精通的完整实战指南 【免费下载链接】bark 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/bark 在AI技术飞速发展的今天&#xff0c;文本到语音转换技术已经成为众多应用场景的核心需求。无论是为视障人士提供辅助工具&a…

作者头像 李华
网站建设 2026/3/4 1:46:35

Docker清道夫?在极空间NAS上部署自动化清理助手『PruneMate』

Docker清道夫&#xff1f;在极空间NAS上部署自动化清理助手『PruneMate』 哈喽小伙伴们好&#xff0c;我是Stark-C~ 我想绝大多数的NAS用户都和我一样&#xff0c;没事的时候折腾最多的就是玩玩Docker容器。今天装个新镜像&#xff0c;明天试个新服务&#xff0c;后天又看到别…

作者头像 李华