当前位置: 首页 > 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://www.jsqmd.com/news/94914/

相关文章:

  • GG3M (鸽姆) Global Governance Meta-Mind Model: 商业计划书 Global Civilization Governance OS (Eastern Wisdom
  • C#+VisionMaster联合开发控件篇(八)_参数配置带渲染窗体
  • 线性表之顺序栈
  • Fedora , Linux 创始人 Linus 的选择 —— 目前他生活在加拿大
  • 基于springboot的药店药品管理系统的设计与实现(源码+lw+远程部署)
  • groovy基础了解
  • 深度解析 Google JAX 全栈:带你上手开发,从零构建神经网络
  • 基于python的药店药品管理系统的设计与实现(源码+lw+远程部署)
  • 2026毕设ssm+vue基于高校新生报到论文+程序
  • 金融数据分析-申万行业数据分析系统(Python+Streamlit)
  • 百度搜索不到的Qwen3-VL-8B安装包获取渠道揭秘
  • 影刀使用全局附值控制操作次数
  • CTF —— 网络安全大赛!从入门到精通,收藏这篇就够了
  • ENSP抓包分析Qwen3-VL-30B API通信协议细节
  • Stm32_2:蜂鸣器、按键、继电器
  • Qwen3-8B vs 其他8B模型:逻辑推理能力全面对比测评
  • 【优化分配】基于遗传算法GA求解机场登机口分配优化问题(目标函数:油耗 靠桥率)附Matlab代码
  • 【2025最新】网络安全从入门到精通(超详细)学习路线!
  • 2026毕设ssm+vue基于高校教师个人主页网站的设计与实现论文+程序
  • 基于FLUX.1-dev的文生图技术博客:提升提示词遵循度的秘诀
  • Hadoop与Python:PySpark大数据处理指南
  • 又一个绿色神器的蓝屏修复工具
  • Comsol微环谐振腔与环形波导耦和:对比波束包络与波动光学两个模块
  • 千匠供应链商城系统:AI赋能、灵活部署,全力助推产业互联网平台建设与发展
  • leetcode56.合并区间
  • C#字典操作全攻略与var定义变量
  • 基于python的房产交易服务平台的设计与实现(源码+lw+远程部署)
  • 2024年提示工程架构师必看:用户参与研究的最新趋势,提升提示设计效果
  • 将结果按字典或元组格式输出
  • Informed RRT*实现椭圆启发式采样