热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【YbtOJ高效进阶贪心3】畜栏预定

小目录链接题目描述样例输入样例输出思路代码链接YbtOJ高效进阶贪心-3题目描述有N头牛在畜栏中吃草。每个畜栏在同一时间段只能提供给一头牛吃草,所以可能会需要多

小目录

    • 链接
    • 题目描述
    • 样例输入
    • 样例输出
    • 思路
    • 代码


链接

YbtOJ高效进阶 贪心-3

题目描述

有N头牛在畜栏中吃草。每个畜栏在同一时间段只能提供给一头牛吃草,所以可能会需要多个畜栏,给出第i头牛开始吃草的时间区间[ai,bi][a_i, b_i][ai,bi] ,求需要的最少畜栏数和每头牛对应的畜栏方案。

样例输入

5
1 10
2 4
3 6
5 8
4 7

样例输出

4
1
2
3
2
4

思路

对每头牛的开始时间从小到大排序
然后贪心?
对于第i个牛,它要么是进新的畜栏,要么是进已经没牛的畜栏
1.进新的畜栏,那只有每个畜栏都有牛,才会开新的畜栏给这头牛
2.进没牛的畜栏,那就要对每个畜栏中的牛的区间用一个小根堆去维护,然后判断即可

代码

#include
#include
#include
#include
#include
#includeusing namespace std;int n, ans[100005];
priority_queue <pair<int, int>, vector<pair<int, int> >, greater<pair<int, int> > > Q;struct tt
{int l, r, num;
}a[100005];bool cmp(tt a, tt b)
{return a.l < b.l;
}int main()
{scanf("%d", &n);for(int i &#61; 1; i <&#61; n; &#43;&#43;i)scanf("%d%d", &a[i].l, &a[i].r), a[i].num &#61; i;sort(a &#43; 1, a &#43; n &#43; 1, cmp);Q.push(make_pair(a[1].r, 1));ans[a[1].num] &#61; 1;for(int i &#61; 2; i <&#61; n; &#43;&#43;i){if(!Q.size() || Q.top().first >&#61; a[i].l) {ans[a[i].num] &#61; Q.size() &#43; 1;Q.push(make_pair(a[i].r, Q.size() &#43; 1));}//对应思路中的第一种情况else {ans[a[i].num] &#61; Q.top().second; Q.pop();Q.push(make_pair(a[i].r, ans[a[i].num]));}//第二种情况} printf("%d\n", Q.size());for(int i &#61; 1; i <&#61; n; &#43;&#43;i)printf("%d\n", ans[i]);
}


推荐阅读
  • 本题要求计算从起点到终点所有最短路径的总权重,使用SPFA算法进行求解。 ... [详细]
  • 题目描述:给定 n 把雨伞和 m 个人,t 分钟后开始下雨。求在每个人只能使用一把雨伞的情况下,最多有多少人可以拿到雨伞。 ... [详细]
  • ZOJ 2760 - 最大流问题
    题目链接:How Many Shortest Paths。题目描述:给定一个包含n个节点的有向图,通过一个n*n的矩阵来表示。矩阵中的a[i][j]值为-1表示从节点i到节点j无直接路径;否则,该值表示从i到j的路径长度。输入起点vs和终点vt,计算从vs到vt的所有不共享任何边的最短路径数量。如果起点和终点相同,则输出无穷大。 ... [详细]
  • 本文详细解析 Skynet 的启动流程,包括配置文件的读取、环境变量的设置、主要线程的启动(如 timer、socket、monitor 和 worker 线程),以及消息队列的实现机制。 ... [详细]
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • 3144:[Hnoi2013]切糕TimeLimit:10SecMemoryLimit:128MBSubmit:1261Solved:700[Submit][St ... [详细]
  • 题目描述墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问。墨墨会像你发布如下指令ÿ ... [详细]
  • HDU1085 捕获本·拉登!
    问题描述众所周知,本·拉登是一位臭名昭著的恐怖分子,他已失踪多年。但最近有报道称,他藏匿在中国杭州!虽然他躲在杭州的一个洞穴中不敢外出,但近年来他因无聊而沉迷于数学问题,并声称如果有人能解出他的题目,他就自首。 ... [详细]
  • 本文探讨了如何利用数组来构建二叉树,并介绍了通过队列实现的二叉树层次遍历方法。通过具体的C++代码示例,详细说明了构建及打印二叉树的过程。 ... [详细]
  • 2022年4月15日的算法练习题,包括最长公共子序列和线段树的应用。 ... [详细]
  • 本文提供了一个关于AC自动机(Aho-Corasick Algorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(fail pointer)来提高字符串匹配效率。 ... [详细]
  • A1166 峰会区域安排问题(25分)PAT甲级 C++满分解析【图论】
    峰会是指国家元首或政府首脑之间的会议。合理安排峰会的休息区是一项复杂的工作,理想的情况是邀请的每位领导人都是彼此的直接朋友。 ... [详细]
  • 本文详细探讨了如何处理包含多种分隔符的字符串分割问题,并提供了一个高效的C++实现方案。 ... [详细]
  • 本文介绍了进程的基本概念及其在操作系统中的重要性,探讨了进程与程序的区别,以及如何通过多进程实现并发和并行。文章还详细讲解了Python中的multiprocessing模块,包括Process类的使用方法、进程间的同步与异步调用、阻塞与非阻塞操作,并通过实例演示了进程池的应用。 ... [详细]
  • LeetCode 102 - 二叉树层次遍历详解
    本文详细解析了LeetCode第102题——二叉树的层次遍历问题,提供了C++语言的实现代码,并对算法的核心思想和具体步骤进行了深入讲解。 ... [详细]
author-avatar
perfect_rl
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有