news 2026/6/23 20:15:22

【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/6/23 1:54:57

云手机 实体手机的云端延伸

云手机可视为实体手机的云端延伸。它基于云计算技术和虚拟化技术&#xff0c;在云端服务器上虚拟出带有原生安卓等操作系统的手机实例&#xff0c;通过网络与实体设备连接&#xff0c;用户可通过实体手机、平板或电脑等设备远程操控云手机&#xff0c;实现诸如运行应用、游戏等…

作者头像 李华
网站建设 2026/6/23 4:13:33

交换机和网卡的 PFC 机制工作原理与实例解析

PFC&#xff08;Priority-based Flow Control&#xff0c;基于优先级的流控&#xff09; 是数据中心以太网&#xff08;如 RoCE v2、DCB&#xff09;的核心技术&#xff0c;属于链路层&#xff08;Layer 2&#xff09;流量控制机制。其核心目标是解决拥塞导致的丢包问题—— 通…

作者头像 李华
网站建设 2026/6/22 19:58:33

UI自动化测试常见面试题

1、什么是UI自动化测试&#xff1f; UI自动化测试是一种通过模拟用户交互并自动执行UI操作的软件测试方法。它用于验证用户界面的功能和稳定性&#xff0c;以确保在不同的操作系统、浏览器和设备上的一致性。 2、UI自动化测试的优势和劣势是什么&#xff1f; 优势&#xff1…

作者头像 李华
网站建设 2026/6/23 18:10:17

Linux OOM 问题之 DMSERVER 受害者

Shell 脚本模拟(无需安装工具) OOM 问题#!/bin/bash #持续申请内存&#xff0c;每次申请 100MB&#xff0c;直到内存耗尽。while true; do # 创建 100MB 临时文件&#xff0c;读取到内存(cat 命令会占用内存)。cat /dev/zero |head -c 100M |tail & done运行脚本&#xff1…

作者头像 李华
网站建设 2026/6/23 2:05:11

Flutter引擎裁剪与鸿蒙方舟编译协同优化

欢迎大家加入开源鸿蒙跨平台开发者社区&#xff0c;一起共建开源鸿蒙跨平台生态。 Flutter引擎裁剪与鸿蒙方舟编译协同优化 Flutter引擎的冗余模块会增加包体积并影响启动速度。通过分析flutter_engine源代码&#xff0c;可识别非必要模块进行裁剪。常见可移除模块包括&#…

作者头像 李华