贪心算法(2024/7/16)

news2025/1/13 15:49:49

1合并区间

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

示例 1:

输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例 2:

输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

思路:本题是判断重叠区间问题  先排序,让所有的相邻区间尽可能的重叠在一起,按左边界,或者右边界排序都可以.

  1. 排序: 首先,根据每个区间的左边界,对给定的区间集合 intervals 进行升序排序。这是为了确保处理区间时,可以按顺序考虑它们的位置关系。

  2. 合并过程: 排序完成后,使用一个结果集合 result 来存储最终合并后的区间。开始时,将排序后的第一个区间直接放入 result 中。

  3. 遍历区间: 从第二个区间开始遍历,与 result 中的最后一个区间比较:

    • 如果当前区间与 result 中的最后一个区间有重叠(即当前区间的左边界小于等于 result 中最后一个区间的右边界),则更新 result 中最后一个区间的右边界为两者的最大值,以实现合并。
    • 如果当前区间与 result 中的最后一个区间没有重叠,则直接将当前区间加入 result

代码

class Solution {
public:
    // 定义一个静态函数作为比较函数,用于排序
    static bool cmp(const vector<int>& a, const vector<int>& b) {
        return a[0] < b[0]; // 按照区间的左边界进行升序排序
    }
    
    vector<vector<int>> merge(vector<vector<int>>& intervals) {
        vector<vector<int>> result;
        if (intervals.empty()) return result; // 如果区间集合为空直接返回空结果
        // 使用cmp函数对区间进行排序
        sort(intervals.begin(), intervals.end(), cmp);

        // 第一个区间直接放入结果集合中
        result.push_back(intervals[0]); 

        for (int i = 1; i < intervals.size(); i++) {
            if (result.back()[1] >= intervals[i][0]) { // 发现重叠区间
                // 合并区间,只需要更新结果集合中最后一个区间的右边界
                result.back()[1] = max(result.back()[1], intervals[i][1]); 
            } else {
                result.push_back(intervals[i]); // 区间不重叠,将当前区间加入结果集合
            }
        }
        return result;
    }
};


2 单调递增的数字

当且仅当每个相邻位数上的数字 x 和 y 满足 x <= y 时,我们称这个整数是单调递增的。

给定一个整数 n ,返回 小于或等于 n 的最大数字,且数字呈 单调递增 。

示例 1:

输入: n = 10
输出: 9

示例 2:

输入: n = 1234
输出: 1234

示例 3:

输入: n = 332
输出: 299

提示:

  • 0 <= n <= 109

思路:

举个例子,数字:332,从前向后遍历的话,那么就把变成了329,此时2又小于了第一位的3了,真正的结果应该是299。

那么从后向前遍历,就可以重复利用上次比较得出的结果了,从后向前遍历332的数值变化为:332 -> 329 -> 299

  1. 将整数 N 转换为字符串 strNum,便于按位处理。
  2. 从右向左遍历字符串 strNum,找到第一个出现递减的位置 i,即满足 strNum[i-1] > strNum[i]
  3. 将第 i-1 位减一,并标记 flag 为 i,表示从这里开始需要调整。
  4. 将从 flag 开始的所有位置的字符设为 ‘9’,以确保得到最大的单调递增数。
  5. 将处理后的字符串转换为整数并返回作为结果。

代码:

class Solution {
public:
    int monotoneIncreasingDigits(int N) {
        string strNum = to_string(N);
        // flag用来标记需要修改的位置,初始化为字符串长度,防止第二个循环在未赋值的情况下执行
        int flag = strNum.size();
        
        // 从倒数第二位开始向前遍历
        for (int i = strNum.size() - 1; i > 0; i--) {
            // 如果当前位大于前一位,则前一位需要减一,并更新flag
            if (strNum[i - 1] > strNum[i]) {
                flag = i; // 记录需要减一的位置
                strNum[i - 1]--; // 前一位减一
            }
        }
        
        // 将flag位置及之后的所有位数变为9,以获得最大的单调递增数
        for (int i = flag; i < strNum.size(); i++) {
            strNum[i] = '9';
        }
        
        return stoi(strNum); // 转换为整数并返回
    }
};

3监控二叉树

给定一个二叉树,我们在树的节点上安装摄像头。

节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。

计算监控树的所有节点所需的最小摄像头数量。

示例 1:

输入:[0,0,null,0,0]
输出:1
解释:如图所示,一台摄像头足以监控所有节点。

示例 2:

输入:[0,0,null,0,null,0,null,null,0]
输出:2
解释:需要至少两个摄像头来监视树的所有节点。 上图显示了摄像头放置的有效位置之一。


提示:

  1. 给定树的节点数的范围是 [1, 1000]
  2. 每个节点的值都是 0。

思路:我们要从下往上看,局部最优:让叶子节点的父节点安摄像头,所用摄像头最少,整体最优:全部摄像头数量所用最少!可以使用后序遍历也就是左右中的顺序,这样就可以在回溯的过程中从下到上进行推导了.

给定一个二叉树,节点状态有三种:未被覆盖、已被覆盖(无需额外摄像头)、已安装摄像头。目标是找出最少需要安装的摄像头数量,覆盖整棵树的所有节点。

定义递归函数 traversal,对当前节点进行处理:

  • 如果左右子树有任意一个是未被覆盖的状态(返回2),则当前节点需要安装摄像头,返回1表示当前节点已安装摄像头。
  • 如果左右子树都已被覆盖(返回0),则当前节点不需要额外的摄像头覆盖。
  • 如果左右子树有一个已安装摄像头(返回1),则当前节点被覆盖,返回0。
  1. 根节点处理: 调用 traversal 函数处理根节点。如果根节点未被覆盖(返回2),则需要额外安装一个摄像头。

  2. 终返回 result,即安装摄像头的总数量。

代码: 

class Solution {
private:
    int result; // 记录需要安装摄像头的数量

    // 递归函数,返回当前节点的状态:
    // 0 - 节点已被覆盖
    // 1 - 节点安装了摄像头
    // 2 - 节点未被覆盖
    int traversal(TreeNode* cur) {
        if (cur == NULL) return 2; // 空节点默认已覆盖

        int left = traversal(cur->left);    // 处理左子树
        int right = traversal(cur->right);  // 处理右子树

        // 如果左右子树有任意一个未被覆盖,当前节点需要安装摄像头
        if (left == 2 || right == 2) {
            result++; // 安装摄像头
            return 1; // 当前节点已安装摄像头
        }
        // 如果左右子树的状态都是已覆盖,当前节点不需要额外摄像头覆盖
        else if (left == 0 && right == 0) {
            return 2; // 当前节点未被覆盖
        } else {
            return 0; // 当前节点已被覆盖
        }
    }

public:
    int minCameraCover(TreeNode* root) {
        result = 0; // 初始化摄像头数量为0
        if (traversal(root) == 2) { // 如果根节点未被覆盖,则需额外安装摄像头
            result++;
        }
        return result; // 返回最终需要安装的摄像头数量
    }
};

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

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

相关文章

MongoDB教程(七):mongoDB分片

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; 文章目录 引言MongoDB 分…

Mysql数据库的概念及sql语法和规范+数据库的用户管理

一、数据库的概念 1.数据库&#xff1a;组织、管理、存储数据的仓库 2.数据库的管理系统&#xff08;DBMS&#xff09;&#xff1a;实现对数据有效组织&#xff0c;管理和存储的系统软件。 3.关系型数据库和非关系性数据库&#xff1a; 关系型数据库&#xff1a;mysql or…

神经网络概述

目录 1. 前馈神经网络(Feedforward Neural Networks, FNNs) 2. 卷积神经网络(Convolutional Neural Networks, CNNs) 3. 循环神经网络(Recurrent Neural Networks, RNNs) 4. 长短期记忆网络(Long Short-Term Memory, LSTM) 5. 门控循环单元(Gated Recurrent Unit…

MSPM0G3507——时钟主频拉到80MHZ

先点开使用时钟树 在配置时钟界面这样配置

【送书活动十期】从零开始node.js制作CLI工具

这篇博客的由来是源于工作中一个java项目的配置项是加密后的私钥&#xff0c;私钥是由其他项目中调用web3生成随机账号得到的&#xff0c;而加密方法只是简单在java项目中执行代码得到。这便导致两步操作有点割裂&#xff0c;需要有一个脚本来完成生成私钥和加密私钥&#xff0…

[Tensor学习]你不得不知道的知识点-切点-反转

wait...突然发现了一个错误&#xff1a; 在tensor里面只有size相同才允许相加&#xff0c; 如果想要相连接&#xff1a; PS: 如果tensor是多维的&#xff0c;比如说 a Tensor([1,2,3], [4,5,6]) 那么有 a[ : , :] a a[0,0] 1 a[ 第一维 &#xff0c;第二维] ...…

乘积量化pq:将高维向量压缩 97%

向量相似性搜索在处理大规模数据集时&#xff0c;往往面临着内存消耗的挑战。例如&#xff0c;即使是一个包含100万个密集向量的小数据集&#xff0c;其索引也可能需要数GB的内存。随着数据集规模的增长&#xff0c;尤其是高维数据&#xff0c;内存使用量会迅速增加&#xff0c…

MAC地址电脑的“身份证”

在电脑的世界里&#xff0c;每个设备都有一个独一无二的标识&#xff0c;就像我们的身份证号码一样。 这个标识被称为MAC地址&#xff08;Media Access Control Address&#xff09;&#xff0c;它是网络设备硬件的唯一识别码。 MAC地址由12个十六进制数字组成&#xff0c;通…

区块链资料

Quantstamp - Public Security Assessments smart-contract-sanctuary-bsc/contracts/mainnet at master tintinweb/smart-contract-sanctuary-bsc GitHub https://github.com/slowmist/Cryptocurrency-Security-Audit-Guide/blob/main/README_CN.md sFuzz: 高效自适应的智…

ArkUI组件——循环控制/List

循环控制 class Item{name: stringprice:number}private items:Array<Item> [new Item("A0",2399),new Item("BE",1999),new Item("Ro",2799)] ForEach(this.items,(item:Item) > {})List组件 列表List是一种复杂的容器&#xff0c;…

小程序里面使用vant ui中的vant-field组件,如何使得输入框自动获取焦点

//.wxml <van-fieldmodel:value"{{ userName }}"placeholder"请输入学号"focus"{{focusUserName}}"/>// .js this.setData({focusUserName: true});vant-field

postgresql删除用户

背景 **角色与用户**&#xff1a;在 PostgreSQL 中&#xff0c;用户和组的概念是通过“角色”来统一实现的。角色可以有登录权限&#xff08;在这种情况下&#xff0c;它们通常被称为“用户”&#xff09;&#xff0c;也可以没有&#xff08;在这种情况下&#xff0c;它们通常用…

网络请求之代理proxy

为什么要用代理呢&#xff1f;这个就涉及到安全问题了&#xff0c;你要是用一个IP频繁的访问人家网站&#xff0c;这不就是在搞事情么&#xff0c;人家网站肯定得把你的IP禁掉。所以我们爬虫的时候就得经常换IP&#xff0c;就是拿别人的IP不同人的IP访问网站去爬取数据。 我们…

AQS源码解析(ReentrantLock)

什么是AQS:Juc中的大多数同步器都是围绕着一些相同的基础行为&#xff0c;比如等待队列&#xff0c;条件队列&#xff0c;共享&#xff0c;独占获取变量这些行为&#xff0c;抽象出来就是基于AQS&#xff08;AbstractQueuedSynchronizer&#xff09;实现的。所以可以把AQS看成这…

昇思学习打卡-18-LLM原理与实践/MindNLP ChatGLM-6B StreamChat

文章目录 模型介绍技术特点运行效果 模型介绍 ChatGLM-6B模型是一个开源的、支持中英双语的对话语言模型&#xff0c;由清华大学和智谱AI联合研发。 技术特点 模型量化技术&#xff1a;ChatGLM-6B结合了模型量化技术&#xff0c;使得用户可以在消费级的显卡上进行本地部署。…

C++动态内存的管理

今天来分享C动态内存管理相关知识&#xff0c;闲言勿谈&#xff0c;直接上干货。 1. 动态内存的开辟和销毁(new和delete) (1)前置知识&#xff1a;我们知道c语言有malloc和calloc和realloc三个函数可以进行动态的开辟内存&#xff0c;那么它们有什么区别呢&#xff1f;首先是…

Module2 DRC Basics

材料链接 calibre_rule_writing_2007 - 道客巴巴https://www.doc88.com/p-330763936895.html Calibre DRC介绍 Calibre nmDRC流程 找寻,查看,纠正DRC冲突的一个完整的过程: 从Layout输入,加上svrf文件,一起输入进nmDRC软件; 输出DRC result数据,summary report,tr…

【经验分享】关于静态分析工具排查 Bug 的方法

文章目录 编译器的静态分析cppcheck安装 cppcheck运行 cppcheck 程序员的日常工作&#xff0c;不是摸鱼扯皮&#xff0c;就是在写 Bug。虽然这是一个梗&#xff0c;但也可以看出&#xff0c;程序员的日常一定绕不开 Bug。而花更少的时间修复软件中的 Bug&#xff0c;且不引入新…

第4章 Express路由的深入理解(二)

4 路由分组 路由分组用于将相关的路由组织在一起&#xff0c;使代码更具模块化和可维护性。可以通过使用 express.Router 创建路由组。 示例&#xff1a; const express require(express); const app express(); const apiRouter express.Router(); const userRouter ex…

【青书学堂】2024年第一学期 保险理论与实务(高起专) 作业

【青书学堂】2024年第一学期 保险理论与实务(高起专) 作业 为了方便日后复习&#xff0c;青书学堂成人大专试题整理。 若有未整理的课程&#xff0c;请私信我补充&#xff0c;欢迎爱学习的同学们收藏点赞关注&#xff01;文章内容仅限学习使用&#xff01;&#xff01;&#xf…