C++ 贪心 区间问题 区间选点

2024-02-11 09:04
文章标签 c++ 问题 贪心 区间 选点

本文主要是介绍C++ 贪心 区间问题 区间选点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

给定 N
个闭区间 [ai,bi]
,请你在数轴上选择尽量少的点,使得每个区间内至少包含一个选出的点。

输出选择的点的最小数量。

位于区间端点上的点也算作区间内。

输入格式
第一行包含整数 N
,表示区间数。

接下来 N
行,每行包含两个整数 ai,bi
,表示一个区间的两个端点。

输出格式
输出一个整数,表示所需的点的最小数量。

数据范围
1≤N≤105
,
−109≤ai≤bi≤109
输入样例:
3
-1 1
2 4
3 5
输出样例:
2

在这里插入图片描述
在这里插入图片描述
这里是一个简单的证明,可以帮助理解为什么要这样选。
假设Ans是答案,也就是最少得点,cnt是我们算法选出来的点,(1)很显然Ans≤cnt。(2)cnt选出来的是没有交集的依次排开的区间的右端点,因此覆盖掉所有的区间的最小值,所需要的点数一定是大于等于cnt的,也就是Ans≥cnt。即证得算法一定可以得到最优解。

#include <iostream>
#include <algorithm>using namespace std;const int N = 100010;int n;struct Range
{int l, r;bool operator< (const Range &w) const{return r < w.r;}
}range[N];int main ()
{scanf("%d", &n);for(int i = 0; i < n; i ++ ){int l, r;scanf("%d%d", &l, &r);range[i] = {l, r};}sort(range, range + n);int res = 0, ed = -2e9; // res是答案,ed是上一个点的下标,因为一开始的时候一个点都没有选,赋值为负无穷for(int i = 0; i < n; i ++ ) // 枚举所有的区间{if(range[i].l > ed) // 如果说当前区间的左端点严格大于上一个选出来的右端点,就更新点{res ++;ed = range[i].r;}}printf("%d\n", res);return 0;
}

这里再顺便复习一下C++的一些知识:
使用了重载运算符来定义结构体 Range 对象的比较行为。具体来说,我们重载了小于运算符 operator<。这个运算符用于比较两个 Range 对象的大小关系。
operator< 被定义为结构体 Range 的成员函数。它允许我们使用小于运算符 < 来比较两个 Range 对象的大小。
在C++中,const 关键字用于声明常量或限定函数成员的行为。在这里,const 关键字的作用如下:
const 修饰成员函数 operator< 的参数 w:这表示函数 operator< 接受一个 const 修饰的 Range 类型的引用 w 作为参数。const 修饰的参数表示在函数内部不能修改参数对象的值,即在 operator< 函数内部,不能修改参数 w 所引用的 Range 对象。
const 修饰成员函数 operator< 自身:这表示函数 operator< 是一个 const 成员函数,即它不会修改对象的成员变量。在 const 成员函数内部,不能修改对象的成员变量,除非这些成员变量被声明为 mutable。

这里写题也可以写成

bool operator< (Range w){return r < w.r;}

这篇关于C++ 贪心 区间问题 区间选点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/699397

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

如何解决Spring MVC中响应乱码问题

《如何解决SpringMVC中响应乱码问题》:本文主要介绍如何解决SpringMVC中响应乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC最新响应中乱码解决方式以前的解决办法这是比较通用的一种方法总结Spring MVC最新响应中乱码解

pip无法安装osgeo失败的问题解决

《pip无法安装osgeo失败的问题解决》本文主要介绍了pip无法安装osgeo失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 进入官方提供的扩展包下载网站寻找版本适配的whl文件注意:要选择cp(python版本)和你py

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa