acwing算法基础之贪心--区间问题

目录

  • 1 基础知识
  • 2 模板
  • 3 工程化

1 基础知识

暂无。。。

2 模板

暂无。。。

3 工程化

题目1:区间选点。给你N个区间,让你在数轴上选一些点,要求N个区间中至少有一个点被选出。求选一些点的最少数目。

解题思路:贪心,按照右端点排序,每次选择右端点,维护一个res和右端点right即刻,如果当前区间左端点大于right,则更新rightres自增。

C++代码如下,

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int main() {int n;cin >> n;vector<pair<int,int>> nums;for (int i = 0; i < n; ++i) {int a, b;cin >> a >> b;nums.emplace_back(a,b);}sort(nums.begin(), nums.end(), [](const pair<int,int> a, const pair<int,int> b) {return a.second < b.second;});int res = 0;int right = -2e9;for (auto [x,y] : nums) {if (x > right) {res += 1;right = y;}}cout << res << endl;return 0;
}

题目2:求最大不相交区间数。给定N个区间,你可以选择一些区间,要求这些区间不能相交,求区间的最大数目。

解题思路:同题目1的解题思路。

C++代码如下,

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int main() {int n;cin >> n;vector<pair<int,int>> nums;for (int i = 0; i < n; ++i) {int a, b;cin >> a >> b;nums.emplace_back(a,b);}sort(nums.begin(), nums.end(), [](const pair<int,int> a, const pair<int,int> b) {return a.second < b.second;});int res = 0;int right = -2e9;for (auto [l, r] : nums) {if (l > right) {res += 1;right = r;}}cout << res << endl;return 0;
}

题目3:给你N个区间,请将它们分成若干组,要求每组内部两两区间互不相交,求组数目的最小值。

关键步骤介绍如下:

  1. 将区间按照左端点排序。
  2. 定义一个小根堆heap,用来存储每个组中所有区间右端点的最大值。
  3. 遍历每个区间[l, r],如果堆顶大于等于l,则将r插入到堆中;否则弹出堆顶,再将r插入到堆中。
  4. 最终答案等价于堆中的元素数目。

C++代码如下,

#include <iostream>
#include <vector>
#include <algorithm>
#include <queue>using namespace std;int main() {int n;cin >> n;vector<pair<int,int>> nums;for (int i = 0; i < n; ++i) {int a, b;cin >> a >> b;nums.emplace_back(a,b);}sort(nums.begin(), nums.end());priority_queue<int, vector<int>, greater<int>> heap;for (auto [l, r] : nums) {if (heap.empty() || heap.top() >= l) {heap.push(r);} else {heap.pop();heap.push(r);}}cout << heap.size() << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/189904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode—1094.拼车【中等】

2023每日刷题&#xff08;四十七&#xff09; Leetcode—1094.拼车 模拟实现代码 bool carPooling(int** trips, int tripsSize, int* tripsColSize, int capacity) {int arr[1003] {0};int numPassenger 0, fromidx 0, toidx 0;for(int i 0; i < tripsSize; i) {num…

【嵌入式Linux程序开发综合实验】-1(附流程图) | ARM开发板 | 测试“Hello World” | Makefile文件 | 实现加法相加

任务&#xff1a;编写在标准输出终端输出“Hello World&#xff01;”的C语言代码以及输入指定数字相加结果、Makefile&#xff0c;并分别编译出在PC与ARM上运行的可执行程序文件。 设备以及工具 硬件&#xff1a;Linux开发板、PC机、串口连接线 图1 Linux开发板以及串口接线 …

ElasticSearch 排障常用方法

文章目录 1&#xff0c;集群状态&#xff0c;节点在线情况&#xff0c;集群参数配置2&#xff0c;查看异常索引、分片&#xff0c;分析异常原因&#xff0c;手动分配分片 1&#xff0c;集群状态&#xff0c;节点在线情况&#xff0c;集群参数配置 GET _cluster/health?pretty…

vmware 安装 AlmaLinux OS 8.6

选择系统镜像 选择镜像 选择安装位置和修改名称 可以自定义硬件&#xff0c;也可以不选择&#xff0c;后面可以再设置 自定义硬件可以设置内存和cpu等信息 安装虚拟机系统 密码如果简单的话需要点击两次done 才能保存

IntelliJ IDEA安装使用教程#intellij idea

做为基础开发软件&#xff0c;idea、pycharm、phpstorm是高级企业级开发中常用的图形化工具。 安装非常简单&#xff1a;去官网下载即可&#xff0c;有社区版本、有企业版本&#xff1a; IntelliJ IDEA – 领先的 Java 和 Kotlin IDE 因版权问题&#xff1a;这里不方面多讲。…

有趣的小算法

找到一个大于等于目标容量的最小的2的幂次方数&#xff0c;常用于实现具有动态扩展能力的数据结构。 示例&#xff1a;HashMap的扩容大小机制。 static final int tableSizeFor(int cap) {int n cap - 1;n | n >>> 1;n | n >>> 2;n | n >>> 4;n …

特殊二叉树——堆

&#x1f308;一、堆的基本概念 1.堆&#xff1a;非线性结构&#xff0c;是完全二叉树 2.堆分为大堆和小堆。 大堆&#xff1a;树中任意一个父亲都大于等于孩子&#xff0c;根节点值大于等于其所有子孙节点的值。 小堆&#xff1a;树中任意一个父亲都小于等于孩子&#xff0c;…

兼容jlink OB arm仿真器使用(杜邦线过长导致烧写总是失败)

一、兼容jlink OB的使用&#xff1a; 1、设置中要选择jlink&#xff1b; 2、模式选择SWD模式&#xff08;接三根线&#xff09;&#xff1b; 二、杜邦线过长导致stm32的stlink烧写总是失败 用ST-link烧写提示的错误信息有&#xff1a; Error while accessing a target reso…

pandas库

目录 一. numpy库二. pandas库读取文件并查看信息基础统计方法函数reset_index() 三. matplotlib四. SciPy五. scikit-learn六. statsmodels 一. numpy库 NumPy&#xff08;http://numpy.org&#xff09;是Numerical Python的简写&#xff0c;是Python数值计算的基石。它提供多…

Redis中的数据结构

文章目录 第1关&#xff1a;Redis中的数据结构 第1关&#xff1a;Redis中的数据结构 这是上篇文章的第一关&#xff0c;只不过本篇是代码按行做的&#xff0c;方便一下大家使用。 代码如下&#xff1a; redis-cliset hello redislpush educoder-list hellorpush educoder-lis…

51单片机制作数字频率计

文章目录 简介设计思路工作原理Proteus软件仿真软件程序实验现象测量误差和范围总结 简介 数字频率计是能实现对周期性变化信号频率测量的仪器。传统的频率计通常是用很多的逻辑电路和时序电路来实现的&#xff0c;这种电路一般运行较慢&#xff0c;而且测量频率的范围较小。这…

AcWing 511:联合权值 ← DFS、链式前向星

【题目来源】https://www.acwing.com/problem/content/513/【题目描述】无向连通图 G 有 n 个点&#xff0c;n−1 条边。 点从 1 到 n 依次编号&#xff0c;编号为 i 的点的权值为 Wi&#xff0c;每条边的长度均为 1。 图上两点 (u,v) 的距离定义为 u 点到 v 点的最短距离。 对…

torch如何将网络参数初始化,又如何将参数还原成原始状态?

1、将网络参数初始化为原始状态 要将网络参数初始化为原始状态&#xff0c;可以使用PyTorch中的权重初始化方法。常见的权重初始化方式包括正态分布、均匀分布、Xavier初始化等。具体步骤如下&#xff1a; 导入torch和torch.nn模块 import torch import torch.nn as nn定义网…

【SpringCloud】注册中心和Ribbon负载均衡

SpringCloud 1.Eureka注册中心 1.1 Eureka的作用 注册中心拉取服务负载均衡远程调用 order-service得知user-service实例地址流程&#xff1a; user-service服务实例启动后&#xff0c;将自己的信息注册到eureka-server&#xff08;Eureka服务端&#xff09;&#xff0c;称…

linux审计工具aureport

aureport是一个用于查看和分析Linux操作系统中的审计日志的命令行工具。 审计日志是一个记录了系统活动、安全事件和资源访问的详细信息的日志文件。它可以帮助管理员监视和追踪系统上发生的各种活动&#xff0c;包括用户登录、文件访问、进程创建、权限更改等。 aureport命令…

二维数组数组指针相关知识

数组指针&#xff1a;数据类型 (*数组指针变量名)[列宽]&#xff1b;特点&#xff1a;1、本质上是一个指针类型的变量&#xff1b;2、指向的是一个二维数组&#xff0c;即数组指针的列宽等价于二维数组的列宽&#xff1b;例如&#xff1a; int array[2][5] {1,2,3,4,5,6,7,8,9…

redis主从复制模式和哨兵机制

目录 第一章、主从复制模式1.1&#xff09;Redis 主从复制模式介绍1.2&#xff09;Redis 主从复制实现、 第二章、哨兵机制2.1&#xff09;容灾处理之哨兵2.2&#xff09;Sentinel 配置 第一章、主从复制模式 1.1&#xff09;Redis 主从复制模式介绍 ①单点故障&#xff1a;数…

Spring中的事务管理

1 基本概念 事务&#xff1a;将一组操作抽象成一个不可再分的单位&#xff0c;这组操作可以有很多个&#xff0c;但是它们要么就全部都执行成功&#xff0c;这时算作事务执行成功&#xff1b;要不其中有操作执行失败&#xff0c;则其余操作都视为执行失败&#xff0c;这时候需…

二叉树的基本操作实现包括创建二叉树、插入节点、搜索节点、删除节点、遍历二叉树等详解

二叉树的基本操作主要包括创建二叉树、插入节点、搜索节点、删除节点、遍历二叉树等。下面是这些基本操作的 Python 代码实现。 创建二叉树 class TreeNode:def __init__(self, value):self.value valueself.left Noneself.right Noneclass BinaryTree:def __init__(self)…

honle电源维修UV电源控制器EVG EPS40C-HMI

好乐UV电源控制器维修&#xff1b;honle控制器维修&#xff1b;UV电源维修MUC-Steuermodul 2 LΛmpen D-82166 主要维修型号&#xff1a; EVG EPS 60/120、EVG EPS 100、EVG EPS200、EVG EPS 220、EVG EPS 340、EVG EPS40C-HMI、EVG EPS60 HONLE好乐uv电源维修故障包括&#…