当前位置: 首页 > news >正文

集合帖:区间问题

一、AcWing 803:区间合并
(1)题目来源:https://www.acwing.com/problem/content/805/
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/145067059

#include <bits/stdc++.h>
using namespace std;const int maxn=1e5+5;
struct Section {int x;int y;
} a[maxn];bool cmp(Section u,Section v) {if(u.x==v.x) return u.y<v.y;return u.x<v.x;
}int main() {int n;cin>>n;for(int i=1; i<=n; i++) {cin>>a[i].x>>a[i].y;}sort(a+1,a+1+n,cmp);int base=a[1].y;int cnt=1;for(int i=1; i<=n; i++) {if(a[i].x<=base) base=max(base,a[i].y);else cnt++,base=a[i].y;}cout<<cnt<<endl;return 0;
}/*
in:
10
-15 -8
-20 23
-2 11
2 22
18 23
11 27
-8 21
-18 14
-17 -12
-23 8
out:
1
*/

二、洛谷 P1496:火烧赤壁
(1)题目来源:https://www.luogu.com.cn/problem/P1496
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/145073398

#include <bits/stdc++.h>
using namespace std;const int maxn=2e5;
struct Point {int x;int y;
} a[maxn];bool cmp(Point u,Point v) {if(u.x==v.x) return u.y<v.y;return u.x<v.x;
}int main() {int n;cin>>n;for(int i=1; i<=n; i++) {cin>>a[i].x>>a[i].y;}sort(a+1,a+1+n,cmp);int cnt=0;int from=a[1].x;int base=a[1].y;for(int i=1; i<=n; i++) {if(a[i].x<=base) base=max(base,a[i].y);else {cnt+=(base-from);from=a[i].x;base=a[i].y;}}cnt+=(base-from);cout<<cnt<<endl;return 0;
}/*
in:
3
-1 1
5 11
2 9
out:
11
*/

三、AcWing 905:区间选点
(1)题目来源:https://www.acwing.com/problem/content/907/
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/142840548

#include <bits/stdc++.h>
using namespace std;const int inf=0x3f3f3f3f;
const int maxn=1e5+5;struct Scope {int le,ri;
} a[maxn];bool up(Scope u,Scope v) {return u.ri<v.ri;
}int main() {int n;cin>>n;for(int i=0; i<n; i++) {cin>>a[i].le>>a[i].ri;}sort(a,a+n,up);int ans=0;int t_ri=-inf;for(int i=0; i<n; i++)if(t_ri<a[i].le) {ans++;t_ri=a[i].ri;}cout<<ans<<endl;return 0;
}/*
in:
3
-1 1
2 4
3 5
out:
2
*/

四、AcWing 906:区间分组
(1)题目来源:https://www.acwing.com/problem/content/908/
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/145081557

#include <bits/stdc++.h>
using namespace std;const int maxn=1e5+5;
pair<int,int> a[maxn];
int n;int main() {cin>>n;for(int i=0; i<n; i++) {cin>>a[i].first>>a[i].second;}sort(a,a+n);priority_queue<int,vector<int>,greater<int>> q;for(int i=0; i<n; i++) {if(q.size() && a[i].first>q.top()) q.pop();q.push(a[i].second);}cout<<q.size()<<endl;return 0;
}/*
in:
10
-15 -8
-20 23
-2 11
2 22
18 23
11 27
-8 21
-18 14
-17 -12
-23 8out:
6
*/

五、AcWing 907:区间覆盖
(1)题目来源:
https://www.acwing.com/problem/content/909/
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/145083747

#include <bits/stdc++.h>
using namespace std;const int maxn=1e5+5;
struct Section {int x;int y;
} a[maxn];bool cmp(Section u,Section v) {if(u.x==v.x) return u.y<v.y;return u.x<v.x;
}int main() {int st,en;cin>>st>>en;int n;cin>>n;for(int i=1; i<=n; i++) {cin>>a[i].x>>a[i].y;}sort(a+1,a+1+n,cmp);int ans=0;bool flag=false;for(int i=1; i<=n; i++) {int j=i,t=INT_MIN;while(j<=n && a[j].x<=st) {t=max(t,a[j].y);j++;}if(t<st) break;ans++;if(t>=en) {flag=true;break;}st=t,i=j-1;}if(!flag) ans=-1;cout<<ans<<endl;return 0;
}/*
in:
1 5
3
-1 3
2 4
3 5out:
2
*/

六、AcWing 802:区间和
(1)题目来源:https://www.acwing.com/problem/content/804/
(2)算法代码:https://blog.csdn.net/hnjzsyjyj/article/details/143309807

#include <bits/stdc++.h>
using namespace std;typedef pair<int,int> PII;
const int maxn=3e5+5;
int a[maxn],s[maxn];
int n,m;
vector<int> alls;
vector<PII> add,query;int find(int x) { //discretizationint le=0;int ri=alls.size()-1;while(le<ri) {int mid=(le+ri)>>1;if(alls[mid]>=x) ri=mid;else le=mid+1;}return ri+1;
}int main() {cin>>n>>m;for(int i=0; i<n; i++) {int x,c;cin>>x>>c;alls.push_back(x);add.push_back({x,c});}for(int i=0; i<m; i++) {int le,ri;cin>>le>>ri;alls.push_back(le), alls.push_back(ri);query.push_back({le,ri});}//de-weightsort(alls.begin(),alls.end());alls.erase(unique(alls.begin(),alls.end()), alls.end());for(auto v:add) {int x=find(v.first);a[x]+=v.second;}for(int i=1; i<=alls.size(); i++) {s[i]=s[i-1]+a[i]; //prefix sum}for(auto v:query) {int le=find(v.first);int ri=find(v.second);cout<<s[ri]-s[le-1]<<endl;}return 0;
}/*
in:
3 3
1 2
3 6
7 5
1 3
4 6
7 8
out:
8
0
5
*/





 

相关文章:

集合帖:区间问题

一、AcWing 803&#xff1a;区间合并 &#xff08;1&#xff09;题目来源&#xff1a;https://www.acwing.com/problem/content/805/ &#xff08;2&#xff09;算法代码&#xff1a;https://blog.csdn.net/hnjzsyjyj/article/details/145067059 #include <bits/stdc.h>…...

C#,入门教程(27)——应用程序(Application)的基础知识

上一篇&#xff1a; C#&#xff0c;入门教程(26)——数据的基本概念与使用方法https://blog.csdn.net/beijinghorn/article/details/124952589 一、什么是应用程序 Application&#xff1f; 应用程序是编程的结果。一般把代码经过编译&#xff08;等&#xff09;过程&#…...

迅翼SwiftWing | ROS 固定翼开源仿真平台正式发布!

经过前期内测调试&#xff0c;ROS固定翼开源仿真平台今日正式上线&#xff01;现平台除适配PX4ROS环境外&#xff0c;也已实现APROS环境下的单机飞行控制仿真适配。欢迎大家通过文末链接查看项目地址以及具体使用手册。 1 平台简介 ROS固定翼仿真平台旨在实现固定翼无人机决策…...

CSS 样式 box-sizing: border-box; 详细解读

box-sizing是 CSS 中的一个属性&#xff0c;用于控制元素的盒模型计算方式。border-box值表示元素的宽度和高度将包括内边距&#xff08;padding&#xff09;和边框&#xff08;border&#xff09;&#xff0c;而不仅仅是内容的宽度和高度。这意味着当你为元素设置宽度和高度时…...

FLASK创建下载

html用a标签 <!-- Button to download the image --> <a href"{{ url_for(download_file, filenameimage.png) }}"><button>Download Image</button> </a> 后端&#xff1a;url_for双大括号即是用来插入变量到模板中的语法。也就是绑…...

漫话架构师|什么是系统架构设计师(开篇)

~犬&#x1f4f0;余~ “我欲贱而贵&#xff0c;愚而智&#xff0c;贫而富&#xff0c;可乎&#xff1f; 曰&#xff1a;其唯学乎” 关注犬余&#xff0c;共同进步 技术从此不孤单...

Web Socket

Web Socket ‌WebSocket‌是一种基于TCP的网络通信协议&#xff0c;允许客户端和服务器之间建立全双工&#xff08;双向&#xff09;通信通道。WebSocket通过HTTP协议进行握手&#xff0c;建立连接后&#xff0c;客户端和服务器可以在同一个连接上同时发送和接收数据&#xff0…...

JavaSE学习心得(反射篇)

反射 前言 获取class对象的三种方式 利用反射获取构造方法 利用反射获取成员变量 利用反射获取成员方法 练习 保存信息 跟配置文件结合动态创建 前言 接上期文章&#xff1a;JavaSE学习心得&#xff08;多线程与网络编程篇&#xff09; 教程链接&#xff1a;黑马…...

使用FRP进行内网穿透

一、基本概念 内网穿透&#xff1a;它是一种网络技术或方法&#xff0c;旨在允许外部网络&#xff08;如互联网&#xff09;访问位于内部网络&#xff08;内网&#xff09;中的设备或服务。由于内部网络通常处于NAT&#xff08;网络地址转换&#xff09;、防火墙或其他安全机制…...

长安“战疫”网络安全公益赛的一些随想

起因 今年刚进入大学&#xff0c;开始带校队&#xff0c;为了培养校队新成员&#xff0c;也就一直计划着和当地的一些高校合作交流&#xff0c;但是由于种种原因一直被搁置下来。正巧学校信息中心和四叶草有一个培训项目的合作&#xff0c;学校的网安协会也算是沾了光成为了培…...

flutter 安卓端打包

在 Flutter 中打包 Android 应用程序是一个相对简单的过程。你可以使用 Flutter 的命令行工具来构建并打包你的 APK 或 AAB&#xff08;Android App Bundle&#xff09;。以下是打包 Flutter Android 应用的步骤&#xff1a; 1. 安装 Flutter 环境 确保你已经安装了 Flutter …...

Cesium中的CustomDataSource 详解

Cesium CustomDataSource 详解 在 Cesium 中&#xff0c;CustomDataSource 是一个强大的类&#xff0c;用于处理自定义的地理数据。它提供了一种方法&#xff0c;可以通过程序方式添加、管理和更新动态的地理实体&#xff0c;而无需依赖外部数据格式&#xff08;如 GeoJSON 或…...

[Qt]常用控件介绍-按钮类控件-QPushButton、QRedioButton、QCheckBox、QToolButton控件

目录 1.QPushButton按钮 介绍 属性 Demo&#xff1a;键盘方向键控制人物移动 2.Redio Button按钮 属性 clicked、pressed、released、toggled区别 单选按钮的分组 Demo&#xff1a;点餐小程序 3.CheckBox按钮 属性 Demo&#xff1a;获取今天的形成计划 4.ToolBu…...

Windows 蓝牙驱动开发-安装蓝牙设备

蓝牙配置文件驱动程序有两种安装类型&#xff1a; 客户端安装&#xff0c;在此类安装中&#xff0c;远程设备播发其服务&#xff0c;并且计算机与之连接。 示例包括&#xff1a;鼠标、键盘和打印机&#xff1b;服务器端安装&#xff0c;在此类安装中&#xff0c;计算机播发服务…...

element表格有横向滚动条时产生错位或者偏移(火狐浏览器)

问题图 解决方法&#xff1a;给表头增加竖向滚动条的宽度 // 解决拖拽表格滚动条&#xff0c;错位问题 ::v-deep .el-table__header-wrapper{padding-right: 20px!important; // 滚动条宽度 }效果图如下&#xff1a;...

C# 下 SQLite 并发操作与锁库问题的 5 种解决方案

开篇&#xff1a;你是否被 SQLite 并发锁库困扰&#xff1f; 在当今数字化的时代浪潮中&#xff0c;数据已然成为了企业与开发者们手中最为宝贵的资产之一。C# 作为一门广泛应用于各类软件开发的强大编程语言&#xff0c;常常需要与数据库进行紧密交互&#xff0c;以实现数据的…...

2025封禁指定国家ip-安装xtables-addons记录

如何安装和使用 安装lux仓库(该仓库包含xtables-addons所需的依赖环境) # wget http://repo.iotti.biz/CentOS/7/noarch/lux-release-7-1.noarch.rpm # rpm -ivh lux-release-7-1.noarch.rpm 安装xtables-addons。注意&#xff1a;必须先安装kmod-xtables-addons&#xff0c;再…...

卷积神经02-CUDA+Pytorch环境安装

卷积神经02-CUDAPytorch环境安装 在使用Python进行pytorch的使用过程中遇到各种各样的版本冲突问题&#xff0c;在此进行记录 0-核心知识脉络 1&#xff09;根据自己电脑的CUDA版本安装对应版本的Pytorch&#xff0c;充分的使用GPU性能2&#xff09;电脑要先安装【CUDA ToolKi…...

高斯数据库与MySQL数据库的区别

高斯数据库与MySQL数据库的区别 在当今数据驱动的时代&#xff0c;选择合适的数据库管理系统&#xff08;DBMS&#xff09;对于项目的成功至关重要。高斯数据库和MySQL作为两款广泛使用的数据库系统&#xff0c;各自具有独特的特点和优势&#xff0c;适用于不同的应用场景。本…...

【 PID 算法 】PID 算法基础

一、简介 PID即&#xff1a;Proportional&#xff08;比例&#xff09;、Integral&#xff08;积分&#xff09;、Differential&#xff08;微分&#xff09;的缩写。也就是说&#xff0c;PID算法是结合这三种环节在一起的。粘一下百度百科中的东西吧。 顾名思义&#xff0c;…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…...

web vue 项目 Docker化部署

Web 项目 Docker 化部署详细教程 目录 Web 项目 Docker 化部署概述Dockerfile 详解 构建阶段生产阶段 构建和运行 Docker 镜像 1. Web 项目 Docker 化部署概述 Docker 化部署的主要步骤分为以下几个阶段&#xff1a; 构建阶段&#xff08;Build Stage&#xff09;&#xff1a…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

使用分级同态加密防御梯度泄漏

抽象 联邦学习 &#xff08;FL&#xff09; 支持跨分布式客户端进行协作模型训练&#xff0c;而无需共享原始数据&#xff0c;这使其成为在互联和自动驾驶汽车 &#xff08;CAV&#xff09; 等领域保护隐私的机器学习的一种很有前途的方法。然而&#xff0c;最近的研究表明&…...

屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!

5月28日&#xff0c;中天合创屋面分布式光伏发电项目顺利并网发电&#xff0c;该项目位于内蒙古自治区鄂尔多斯市乌审旗&#xff0c;项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站&#xff0c;总装机容量为9.96MWp。 项目投运后&#xff0c;每年可节约标煤3670…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南

&#x1f680; C extern 关键字深度解析&#xff1a;跨文件编程的终极指南 &#x1f4c5; 更新时间&#xff1a;2025年6月5日 &#x1f3f7;️ 标签&#xff1a;C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言&#x1f525;一、extern 是什么&#xff1f;&…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解

在 C/C 编程的编译和链接过程中&#xff0c;附加包含目录、附加库目录和附加依赖项是三个至关重要的设置&#xff0c;它们相互配合&#xff0c;确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中&#xff0c;这些概念容易让人混淆&#xff0c;但深入理解它们的作用和联…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...