2026年|亲测DeepSeek全套降AI率指令+工具:最新降AI方法指南
2026/6/1 11:05:46
在算法领域,贪心算法以其 “局部最优推导全局最优” 的核心思想,成为解决资源调度类问题的经典思路。活动安排问题作为贪心算法的典型应用场景,能直观体现这一思想的价值。本文将从问题分析入手,拆解贪心策略的设计逻辑,结合完整代码实现,详解如何高效解决活动安排问题。
活动安排问题的核心场景是:给定若干个共享同一资源(如会议室、体育场)的活动,每个活动有唯一的开始时间和结束时间,资源同一时间仅能被一个活动占用。我们需要找到一种安排方式,使得能被成功安排的活动数量最多,最大化资源利用率。
以本文实现的场景为例:假设有 10 个活动申请使用同一场地,场地开放时间为 0 时至 24 时,每个活动随机生成开始时间s和结束时间f(s < 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; }通过activity结构体封装每个活动的编号、开始时间、结束时间、持续时间,便于统一管理和排序操作,符合面向过程编程中 “数据聚合” 的设计思路。
selectsortgreedytime变量记录场地当前最早可用时间,初始值为场地开放时间(0 时)。a[i].s >= time:确保当前活动与已安排活动无时间冲突,满足条件则安排该活动,并更新time为当前活动的结束时间。main活动安排问题的核心是贪心算法 “局部最优” 策略的落地 —— 通过选择结束时间最早的活动,实现全局最多活动的安排。本文从问题分析到代码实现,修正了原代码的核心错误(排序逻辑),完善了随机数生成逻辑,同时拆解了每个模块的设计思路。
通过本次实践可深刻体会:贪心算法的关键在于 “最优子结构” 的识别(即局部最优能推导全局最优),而代码实现的细节(如排序依据、条件判断)直接决定算法是否有效。掌握这一思路后,可将其迁移到区间调度、任务选择等同类问题中,提升算法应用能力。
题——
rand的注释,保证每次运行生成不同的活动时间,模拟真实场景的随机性。rand()函数控制开始时间范围为 0-23,结束时间大于开始时间且≤24,避免出现无效的时间区间。sort函数(基于快速排序,O (n log n)),需为结构体重载比较规则。