news 2026/4/30 13:59:12

【ACWing】111. 畜栏预定

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【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)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 23:27:14

测试工程师必会技能合集,这一篇全讲清楚了!

经常会有小伙伴询问&#xff1a;“测试工程师有哪些必须要掌握的技能&#xff1f;”这是一个非常大的课题&#xff0c;因为每个人从事的行业不同、岗位不同&#xff0c;需要掌握的技能自然也不一样。 今天小编就从不同岗位、不同行业两个大方面&#xff0c;来讲讲软件测试工程…

作者头像 李华
网站建设 2026/5/1 8:14:50

Linux网络编程—数据链路层

第一章&#xff1a;数据链路层 数据链路层 用于两个设备&#xff08;同一种数据链路节点&#xff09;之间进行传递 认识以太网 “以太网” 不是一种具体的网络&#xff0c;而是一种技术标准&#xff1b;既包含了数据链路层的内容&#xff0c;也包含了一些物理层的内容。例如…

作者头像 李华
网站建设 2026/5/1 6:50:40

约翰霍普金斯大学World-in-World:革新AI世界模型评估

这项由约翰霍普金斯大学张嘉瀚团队牵头&#xff0c;联合北京大学、普林斯顿大学、MIT、哈佛大学等多所知名院校研究人员的突破性研究&#xff0c;于2025年10月发表在计算机视觉领域顶级会议上。有兴趣深入了解的读者可以通过论文编号arXiv:2510.18135查询完整论文。这项研究首次…

作者头像 李华
网站建设 2026/5/1 6:49:36

线性表之顺序栈

栈是限制在一端进行插入操作和删除操作的线性表&#xff08;俗称堆栈&#xff09;允许进行操作的一端称为”栈顶“另一固定端称为”栈底“当栈中没有元素时称为”空栈“特点&#xff1a;后进先出&#xff08;LIFO&#xff09;或先进后出顺序栈是顺序表的一种&#xff0c;具有顺…

作者头像 李华
网站建设 2026/5/1 7:51:52

基于单片机的智能电梯控制系统设计

系统总体设计概述 点击链接下载设计资料&#xff1a;https://download.csdn.net/download/qq_39020934/92091124 1.1 设计背景与研究意义 随着城市化进程的不断推进&#xff0c;高层建筑数量迅速增加&#xff0c;电梯已经成为现代建筑中最重要的垂直运输工具之一。电梯的运行…

作者头像 李华