I- yh的线段(2023河南萌新联赛第(四)场:河南大学)
链接:登录—专业IT笔试面试备考平台_牛客网
来源:牛客网
yh喜欢好线段,好线段即两条线段相交且不与其他线段重合的线段。
两条线段[l1,r1]和[l2,r2]相交(如果存在至少一个x,使得l1≤x≤r1和l2≤x≤r2,则认为两个线段相交)。
yh在数轴上有几条线段,他可以把在数轴上相交的线段结合,但是对于每个线段只能与其它线段结合一次,且不能与其它线段有重合部分,yh可以舍弃任何数量的线段。
给你nn (2≤n≤1e6)条线段,如果两条线段相交且不与其他线段相交,则由这两条线段组成的线段被称为好线段,线段不能被重复使用,但可以被舍弃任意数量的线段,请你找出好线段个数的最大值。
输入描述:
第一行包含一个正数nn (2≤n≤1e6)——线段的个数。 接下来 nn行各包含两个整数li 和 ri (0≤li≤ri≤10^9,表示n 个线段。
输出描述:
输出好线段个数的最大值。
示例1
输入
复制
5 2 2 2 8 0 10 1 2 5 6
输出
复制
1
示例2
输入
复制
7 2 4 9 12 2 4 7 7 4 8 10 13 6 8
输出
复制
3
说明
对于样例2,我们可以删除[4,8]这一条线段,然后将[2,4]和[2,4]、[6,8]和[7,7]、[9,12]和[10,13]组成三条好线段,可以看出这是最优的情况。
思路:
将所有线段,按照右端点从小到大进行排序。找到俩俩包含的,如果后面出现想包裹住前面的直接跳过;

当出现俩俩融合一线段之后,又出现一条直线想包含其中一条直线,那直接跳过

#include<iostream>
#include<cmath>
#include<cstring>
#include<cstdio>
#include<stack>
#include<string>
#include<algorithm>
#include<unordered_map>
#include<map>
#include<bitset>
#include<cstring>
#include <unordered_set>
//#include<priority_queue>
#include<queue>
#include<deque>
#include<set>
#include<stdlib.h>
#define dbug cout<<"hear!"<<endl;
#define rep(a,b,c) for(ll a=b;a<=c;a++)
#define per(a,b,c) for(ll a=b;a>=c;a--)
#define no cout<<"NO"<<endl;
#define yes cout<<"YES"<<endl;
#define endl "\n"
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
//priority_queue<int,vector<int>,greater<int> >q;
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<ll, ll> PII;
typedef pair<long double,long double> PDD;ll INF = 0x3f3f3f3f;
//const ll LINF=LLONG_MAX;
// int get_len(int x1,int y1,int x2,int y2)
// {
// return (x2-x1)*(x2-x1) + (y2-y1)*(y2-y1);
// }
const ll N = 1e6+ 10;
const ll mod1 =998244353;
const ll mod2 =1e9+7;
const ll hash_num = 3e9+9;
ll n,m,ca, k,ans;
ll arr[N],brr[N],crr[N];
//ll h[N],ne[N],e[N],w[N],book[N],idx;struct node
{ll l, r;
}noda[N];bool cmp(node a,node b)
{if(a.r==b.r){return a.l>b.l;}return a.r<b.r;
}void solve()
{cin >> n;rep(i,1,n){cin >> noda[i].l >> noda[i].r;}sort(noda+1,noda+1+n,cmp);ll ans=0;ll f=-1,r=-1;// cout << endl;// rep(i,1,n)// {// cout << noda[i].l <<" "<<noda[i].r<<endl;// }// cout << endl;rep(i,1,n){if(noda[i].l<=f)continue;else if(noda[i].l<=r){ans++;f=noda[i].r;}else{r=noda[i].r;}// cout << f << " "<<r<<endl;}cout << ans;
}int main()
{IOS;ll _;_=1;//get_eulers();//scanf("%lld",&_);//cin>>_;ca=1;while(_--){solve(); ca++;} return 0;
}
相关文章:
I- yh的线段(2023河南萌新联赛第(四)场:河南大学)
链接:登录—专业IT笔试面试备考平台_牛客网 来源:牛客网 yh喜欢好线段,好线段即两条线段相交且不与其他线段重合的线段。 两条线段[l1,r1]和[l2,r2]相交(如果存在至少一个x,使得l1≤x≤r1和l2≤x≤r2,则认为两个线段…...
python与深度学习(十四):CNN和IKUN模型二
目录 1. 说明2. IKUN模型的CNN模型测试2.1 导入相关库2.2 加载模型2.3 设置保存图片的路径2.4 加载图片2.5 图片预处理2.6 对图片进行预测2.7 显示图片 3. 完整代码和显示结果4. 多张图片进行测试的完整代码以及结果 1. 说明 本篇文章是对上篇文章猫狗大战训练的模型进行测试。…...
chrome扩展在popup、background、content之间通信解决传输文件问题
文章目录 背景介绍案例介绍代码示例popup页面,上传文件页面popup页面,js上传代码,file文件转base64background监听消息,base64转file文件,axios上传 附-转base64后直接下载 背景介绍 示例扩展API版本MV2。 以弹…...
Oracle获取创建对象的DDL脚本
Oracle获取创建对象的DDL脚本 Oracle获取创建对象的DDL脚本查看 dbms_metadata.get_ddl()函数的定义 Oracle获取创建对象的DDL脚本 例如,对tzq schema下的表 test2,查看DDL脚本的SQL如下: SELECT SELECT dbms_metadata.get_ddl(upper(table…...
《算法竞赛·快冲300题》每日一题:“01树”
《算法竞赛快冲300题》将于2024年出版,是《算法竞赛》的辅助练习册。 所有题目放在自建的OJ New Online Judge。 用C/C、Java、Python三种语言给出代码,以中低档题为主,适合入门、进阶。 文章目录 题目描述题解C代码Java代码Python代码 “ 0…...
Mac提示文件:已损坏,无法打开。你应该把它移到废纸篓
文章目录 一、电脑信息二、打开任何来源设置三、更改应用程序拓展属性 一、电脑信息 我的是新版的Venture 13的系统。UI改的比较多。与之前的配置还是有很大的区别的。 打开下载的软件,显示已经损坏,打不开。抛开软件本身的问题外,一般是Ma…...
探索嵌入式系统:从入门到实践
随着科技的飞速发展,嵌入式系统已经成为了我们生活中不可或缺的一部分。从智能手机、智能家居到工业自动化设备,嵌入式系统的应用已经渗透到了各个领域。那么,如何学习嵌入式系统呢?本文将从入门到实践,为你详细解答。…...
网络安全知识点整理(作业2)
目录 一、js函数声明->function 第一种 第二种 第三种 二、this关键字 this使用场合 1.全局环境 2.构造函数 3.对象的方法 避免多层this 三、js的同步与异步 定时器 setTimeout和setInterval 同步与异步的例子 四、宏任务与微任务 分辨宏任务与微任务 一、js…...
idea数据库快速上手-库操作与表结构和数据操作
引言 对数据库的操作无非就是执行SQL语句,要想熟练操作数据库,就要熟练运用SQL语句。 一,数据库操作 展示当前服务器内的数据库 -- 展示服务器内的数据库 show databases; show schemas; 执行结果: 创建数据库: --…...
当“国潮”遇见“双语” 以传承之心种下一颗文化的种子
看,活灵活现的纸片人在“跳舞”。光影的辉映下,两个形神兼备的“齐天大圣”究竟孰真孰假?舞台上,京西皮影非遗传承人王熙和5岁的Mona小朋友正在用双语为大家带来一段“真假美猴王”的好戏。生动的皮影造型和精彩的故事演绎看得台下…...
计划管理与项目管理:有何区别?
简而言之,是的。尽管它们经常互换使用并对全局产生影响,但它们是完全不同的。 在本文中,我们将了解计划和项目管理之间的差异,提供每个示例,并向您展示如何使计划和项目管理工作更有效地实现您的业务目标。 计划管理与…...
个人信息保护合规审计如何做?
8月3日,为指导、规范个人信息保护合规审计活动,根据《中华人民共和国个人信息保护法》等法律法规,国家互联网信息办公室就《个人信息保护合规审计管理办法(征求意见稿)》(简称《办法》)及配套的…...
HTTP杂谈之Referer和Origin请求头再探
一 关于Referer和Origin的汇总 1) 知识是凌乱的,各位看官看个热闹即可2) 内容不断更新1、理解有盲区,需要及时纠正2、内容交叉有重复,需要适当删减3、扩展视野3) 以下内容都与Referer和Origin请求头有关联 nginx防盗链 HTTP杂谈之Referrer-Policy响应头 iframe标签referre…...
数学建模-爬虫入门
Python快速入门 简单易懂Python入门 爬虫流程 获取网页内容:HTTP请求解析网页内容:Requst库、HTML结果、Beautiful Soup库储存和分析数据 什么是HTTP请求和响应 如何用Python Requests发送请求 下载pip macos系统下载:pip3 install req…...
HSRM各表
文章目录 表规则接口种类服务与网关路由菜单一、采购申请1、采购申请—查询2、采购申请-操作记录二、采购申请跟踪报表1、采购申请跟踪报表—列表查询三、寻源1、寻源大厅—列表查询2、寻源大厅—询价单明细3、寻源大厅—物料明细4、寻源大厅—供应商列表5、寻源模板—列表查询…...
Ansible自动化运维工具 —— Playbook 剧本
playbooks 本身由以下各部分组成 (1)Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行 (2)Variables:变量 (3)Templates:模…...
第二章:多态
系列文章目录 文章目录 系列文章目录前言多态的概念概念 多态的定义及实现多态的构成条件虚函数虚函数的重写C11 override 和 final重载、覆盖(重写)、隐藏(重定义)的对比 抽象类概念接口继承和实现继承 多态的原理虚函数表多态的原理动态绑定与静态绑定 单继承和多继承关系的虚…...
C++面向对象设计基础
一般类、&、const、模板、友元函数、操作符重载基本用法及实现 complex.h #ifndef COMPLEX_H #define COMPLEX_H #include<ostream> using namespace std;template<typename T> class Complex{public:Complex():re(0),img(0){}// 为什么构造函数不能传引用&a…...
Linux定时运行sh脚本,如果sh文件已经在运行,则忽略本次运行
需求来源 我需要linux的crontab定期每10分钟运行lan.sh脚本。但由于lan.sh运行需要较长时间,有时超过10分钟。这样会导致系统多次运行lan.sh脚本,引发运行堆积,导致一些非必要的错误。 解决方法 解决方法是写一个脚本,如果lan.…...
SpringBoot项目中的web安全防护
最近这个月公司对项目进行了几次安全性扫描,然后扫描出来了一些安全漏洞,所以最近也一直在修复各种安全漏洞,还有就是最近在备考软考高级系统架构设计师,也刚好复习到了网络安全这一个章节,顺便将最近修复的安全漏洞总…...
mysql如何实现数据库降序输出_使用order by字段desc语句
ORDER BY 字段 DESC 未生效最可能因无索引导致优化器跳过排序,或子查询/视图中排序被忽略;复合索引需方向匹配,字符串排序受collation影响,时间字段降序分页用OFFSET性能差。ORDER BY 字段 DESC 为什么没生效常见现象是写了 ORDER…...
从物理方程到AI生成:手把手图解SDE如何统一DDPM、NCSN等扩散模型
从物理方程到AI生成:图解SDE如何统一扩散模型家族 在咖啡厅里,我经常看到算法工程师们对着扩散模型的数学推导皱眉——那些随机微分方程(SDE)符号像天书般令人望而生畏。但当我用物理实验室的弹簧振子演示噪声如何影响运动轨迹时&…...
小米澎湃OS日志抓取全攻略:从拨号盘暗码到问题反馈,手把手教你定位手机卡顿、Wi-Fi断流等疑难杂症
小米澎湃OS日志抓取实战指南:精准定位卡顿、断流问题的全流程解析 当你的小米手机突然卡成幻灯片,或是Wi-Fi信号像过山车一样时断时续,那种抓狂的感觉我太懂了。去年我帮朋友排查一部频繁死机的小米13时,发现系统日志就像手机的&q…...
C语言struct使用避坑指南:从‘declaration does not declare anything‘报错说起
C语言struct使用避坑指南:从declaration does not declare anything报错说起 在C语言开发中,结构体(struct)是最基础也最常用的复合数据类型之一。但正是这种看似简单的语法特性,却隐藏着不少容易踩坑的细节。许多开发者在代码审查或调试过程…...
Eigen 3.4.90 矩阵操作实战 | C++高效线性代数指南(一)
1. Eigen库基础入门:从安装到第一个矩阵 第一次接触Eigen时,我完全被它的简洁性震惊了——不需要链接任何库文件,只需要包含头文件就能开始高性能的线性代数计算。作为C中最受欢迎的矩阵运算库之一,Eigen 3.4.90版本在保持轻量级的…...
从GitHub源码到可运行项目:手把手教你编译和调试netDxf(C# DXF库)
从GitHub源码到可运行项目:深入探索netDxf库的编译与调试实战 对于希望超越NuGet包基础使用的C#开发者而言,直接操作netDxf库的源代码不仅能解决特定业务场景的定制需求,更是理解DXF文件格式底层逻辑的绝佳途径。本文将带你从GitHub仓库克隆开…...
告别轮询:深入理解RDMA Verbs中的CQ事件通知机制(ibv_req_notify_cq与ibv_get_cq_event实战)
深入解析RDMA Verbs中的CQ事件驱动模型:从轮询到异步通知的进阶实践 在追求极致性能的分布式系统中,RDMA技术已经成为突破传统网络性能瓶颈的关键利器。而作为RDMA编程核心的Verbs接口中,完成队列(CQ)的处理机制直接影…...
STM32 HAL库实战:DMA串口通信避坑指南(附CubeMX配置)
STM32 HAL库实战:DMA串口通信避坑指南(附CubeMX配置) 1. 为什么DMA串口通信值得投入时间掌握? 第一次在STM32项目中使用DMA串口通信时,我盯着屏幕上的数据乱码整整调试了三天。直到发现CubeMX里那个不起眼的"Memo…...
从时钟树到中断回调:图解S32K3的STMPIT完整工作流程
从时钟树到中断回调:图解S32K3的STM&PIT完整工作流程 在汽车电子领域,精确的定时控制如同车辆的神经系统,协调着各个ECU的运作节奏。S32K3系列MCU作为NXP面向新一代汽车架构的核心控制器,其内置的STM(系统定时器模…...
Android14 OTA升级踩坑实录:如何正确配置logo分区避免权限错误
Android14 OTA升级中logo分区配置的深度解析与实战指南 最近在适配Android14系统时,不少开发团队反馈OTA升级过程中频繁遇到logo分区相关的权限错误。这类问题往往在项目初期埋下隐患,直到后期OTA测试阶段才暴露出来。本文将从一个真实案例出发…...
