当前位置: 首页 > news >正文

【ACWing】111. 畜栏预定

题目地址:

https://www.acwing.com/problem/content/113/

N NN头牛在畜栏中吃草。每个畜栏在同一时间段只能提供给一头牛吃草,所以可能会需要多个畜栏。给定N NN头牛和每头牛开始吃草的时间A AA以及结束吃草的时间B BB,每头牛在[ A , B ] [A,B][A,B]这一时间段内都会一直吃草。当两头牛的吃草区间存在交集时(包括端点),这两头牛不能被安排在同一个畜栏吃草。求需要的最小畜栏数目和每头牛对应的畜栏方案。

输入格式:
1 11行:输入一个整数N NN
2.. N + 1 2..N+12..N+1行:第i + 1 i+1i+1行输入第i ii头牛的开始吃草时间A AA以及结束吃草时间B BB,数之间用空格隔开。

输出格式:
1 11行:输出一个整数,代表所需最小畜栏数。
2.. N + 1 2..N+12..N+1行:第i + 1 i+1i+1行输出第i ii头牛被安排到的畜栏编号,编号是从1 11开始的连续整数,只要方案合法即可。

数据范围:
1 ≤ N ≤ 50000 1≤N≤500001N50000,
1 ≤ A , B ≤ 1000000 1≤A,B≤10000001A,B1000000

本质上,问题可以转换为,给定若干闭区间,要求将它们分组,使得同一组内的区间两两不相交,问最少的分组数,和分组方案。思路和证明参考https://blog.csdn.net/qq_46105170/article/details/113734794。代码如下:

#include<algorithm>#include<iostream>#include<queue>usingnamespacestd;constintN=5e4+10;intn;structCow{intid,l,r;}cow[N];intres[N];intmain(){scanf("%d",&n);for(inti=1;i<=n;i++){cow[i].id=i;scanf("%d%d",&cow[i].l,&cow[i].r);}sort(cow+1,cow+1+n,[&](auto&c1,auto&c2){returnc1.l<c2.l;});autocmp=[&](auto&c1,auto&c2){returnc1.r>c2.r;};priority_queue<Cow,vector<Cow>,decltype(cmp)>heap(cmp);intid=0;for(inti=1;i<=n;i++){auto&c=cow[i];if(heap.size()&&heap.top().r<c.l){autoctop=heap.top();heap.pop();res[c.id]=res[ctop.id];}elseres[c.id]=++id;heap.push(c);}printf("%d\n",id);for(inti=1;i<=n;i++)printf("%d\n",res[i]);}

时间复杂度O ( N log ⁡ N ) O(N\log N)O(NlogN),空间O ( N ) O(N)O(N)

http://icebutterfly214.com/news/110172/

相关文章:

  • 影刀使用全局附值控制操作次数
  • leetcode56.合并区间
  • 解放生产力!斯坦福让多智能体学会“自主优化”,告别繁琐配置,AI团队自己“找最优解”
  • Google广告成本飙升?3个着陆页优化技巧质量得分突破
  • 狂中Nature子刊!CNN-LSTM做时间序列预测火力全开,思路非常上头!
  • C#+VisionMaster联合开发控件篇(六)_参数配置控件
  • mysql —— Ubuntu —— 第一次登入,如何设置密码
  • 【毕业设计】基于JAVA的菜鸟驿站存取件管理系统设计与实现基于Java Web的校园菜鸟驿站管理系统(源码+文档+远程调试,全bao定制等)
  • 告别选题迷茫、文献繁杂、写作卡顿!虎贲等考 AI,学术研究全流程智能引擎,做你的私人学术加速器
  • 豆包 AI 手机登录微信被「踢下线」,原因为何?端侧 AI 与头部应用的生态兼容上存在哪些挑战?
  • 豆包手机助手技术预览版发布,AI直接嵌入操作系统底层有何意义?会对行业产生什么影响?
  • 【Agent】MemOS 源码笔记---(5)---记忆分类
  • 校园招聘会组织不再难,统筹安排让就业季更顺畅
  • Java毕设选题推荐:基于springboot高校师资管理系统教师管理、学院管理、专业信息管理、职称调整管理、课程安排管理、进修学习管理、进修汇【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 【课程设计/毕业设计】基于springboot果蔬种植销售一体化服务平台的设计与实现果蔬信息、果蔬入库【附源码、数据库、万字文档】
  • 31、Linux进程管理实战:回收机制、exec族函数与路径操作
  • AI从“玩具”到“工具”的鸿沟如何跨越?一文读懂智能体工程Agent Engineering!
  • 自动化测试的未来:超越脚本编写
  • 测试中的区块链技术应用
  • 为什么顶尖团队都在用Laravel 13自动生成API文档?真相令人震惊
  • 纤维协程任务调度深度解析(优先级调度实战手册)
  • 滑膜控制下的差动制动防侧翻稳定系统设计与仿真验证:横摆力矩分配策略及其实车测试分析
  • 从田间到R控制台,方差分析如何改变传统农业决策?
  • 手搓除灰控制系统:从梯形图到组态的那些坑
  • 推荐几款常用Web自动化测试神器!
  • GitHub 热榜项目 - 日榜(2025-12-15)
  • ShardingSphere分库分表实战
  • JAVA毕业设计257—基于Java+Springboot+vue3的高校招投标系统(源代码+数据库+开题)
  • 【PHP性能优化关键一步】:深入PHP 8.6内存泄漏监控与自动预警方案
  • 内存分配效率低?你可能忽略了这个关键问题,90%的系统都存在