热门标签 | 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]);
}


推荐阅读
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
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社区 版权所有