24暑假算法刷题 | Day30 | 贪心算法 IV | 452. 用最少数量的箭引爆气球,435. 无重叠区间,763. 划分字母区间

news2024/9/20 6:01:43

目录

  • 452. 用最少数量的箭引爆气球
    • 题目描述
    • 题解
  • 435. 无重叠区间
    • 题目描述
    • 题解
  • 763. 划分字母区间
    • 题目描述
    • 题解


452. 用最少数量的箭引爆气球

点此跳转题目链接

题目描述

有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points ,其中points[i] = [x_start, x_end] 表示水平直径在 x_startx_end之间的气球。你不知道气球的确切 y 坐标。

一支弓箭可以沿着 x 轴从不同点 完全垂直 地射出。在坐标 x 处射出一支箭,若有一个气球的直径的开始和结束坐标为 x_startx_end, 且满足 x_start ≤ x ≤ x_end,则该气球会被 引爆 。可以射出的弓箭的数量 没有限制 。 弓箭一旦被射出之后,可以无限地前进。

给你一个数组 points返回引爆所有气球所必须射出的 最小 弓箭数

示例 1:

输入:points = [[10,16],[2,8],[1,6],[7,12]]
输出:2
解释:气球可以用2支箭来爆破:
-在x = 6处射出箭,击破气球[2,8]和[1,6]。
-在x = 11处发射箭,击破气球[10,16]和[7,12]。

示例 2:

输入:points = [[1,2],[3,4],[5,6],[7,8]]
输出:4
解释:每个气球需要射出一支箭,总共需要4支箭。

示例 3:

输入:points = [[1,2],[2,3],[3,4],[4,5]]
输出:2
解释:气球可以用2支箭来爆破:
- 在x = 2处发射箭,击破气球[1,2]和[2,3]。
- 在x = 4处射出箭,击破气球[3,4]和[4,5]。

提示:

  • 1 <= points.length <= 105
  • points[i].length == 2
  • -231 <= xstart < xend <= 231 - 1

题解

贪心算法解决。先按照气球的左边界从小到大(按右边界同理)对 points 进行排序。然后,符合直觉地,应该依次尝试将下一个气球“纳入”当前的“命中范围”,从而将所有气球分成连续紧挨着的若干组,每组用一只箭即可“贯穿”。

这个“命中范围”的左边界就是当前气球左边界(最大的),右边界就是目前这组气球右边界的最小值。如果新的气球的左边界已经大于之前一组气球的右边界,即它肯定会与前一组气球的命中范围“错开”,则开始新一组。

代码(C++)

int findMinArrowShots(vector<vector<int>> &points)
{
    auto cmp = [](const vector<int> &a, const vector<int> &b) {return a[0] < b[0];};
    sort(points.begin(), points.end(), cmp); // 先对points排序
    int count = 1;
    int curMin = points[0][0], curMax = points[0][1];
    for (int i = 1; i < points.size(); ++i) {
        if (points[i][0] > curMax) { // 需要开始新一组
            curMin = points[i][0], curMax = points[i][1];
            count++;
        } else 
            curMin = points[i][0], curMax = min(curMax, points[i][1]); // 更新左右边界
    }
    return count;
}

435. 无重叠区间

点此跳转题目链接

题目描述

给定一个区间的集合 intervals ,其中 intervals[i] = [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠

示例 1:

输入: intervals = [[1,2],[2,3],[3,4],[1,3]]
输出: 1
解释: 移除 [1,3] 后,剩下的区间没有重叠。

示例 2:

输入: intervals = [ [1,2], [1,2], [1,2] ]
输出: 2
解释: 你需要移除两个 [1,2] 来使剩下的区间没有重叠。

示例 3:

输入: intervals = [ [1,2], [2,3] ]
输出: 0
解释: 你不需要移除任何区间,因为它们已经是无重叠的了。

提示:

  • 1 <= intervals.length <= 105
  • intervals[i].length == 2
  • -5 * 104 <= starti < endi <= 5 * 104

题解

贪心算法解决。这题和 452. 用最少数量的箭引爆气球 蛮像的,因为要“ 去除 重叠区间”自然得先“ 找到 重叠区间”。还是先对原区间集合按照左边界从小到大(按右边界同理)排序,然后“贪心”地在顺序遍历过程中找到那些“互相重叠”的区间。

这里的“互相重叠”指的是两两之间都重叠,例如:

在这里插入图片描述

上面每条线段表示一个区间。可以看出,任意两线段(区间)之间都有重叠区域,即这三个区间互相重叠。而如果是下面这种情况:

在这里插入图片描述

第1、2个区间有重叠,第2、3个区间有重叠,但是1、3区间无重叠,则这仨不是“互相重叠”。

然后,每组“互相重叠”的区间最终应该只能保留其中某一个区间,从而组成最后的无重叠区间。因此,找到了互相重叠区间的数量,也就等于找到了最终无重叠区间的数量,那么用原区间的数量减去它,自然就是要移除区间的最小数量了。

代码(C++)

int eraseOverlapIntervals(vector<vector<int>> &intervals)
{
    if (intervals.size() == 1)
        return 0;
    
    auto cmp = [](const vector<int> &a, const vector<int> &b) {
        return a[0] < b[0];
    };
    sort(intervals.begin(), intervals.end(), cmp);
    
    int iCount = 1; // 最终的无重叠区间数量
    int curMinRight = intervals[0][1];
    for (int i = 1; i < intervals.size(); ++i) {
        if (intervals[i][0] >= curMinRight) {
            iCount++;
            curMinRight = intervals[i][1];
        } else 
            curMinRight = min(intervals[i][1], curMinRight);
    }
    return intervals.size() - iCount;
}

763. 划分字母区间

点此跳转题目链接

题目描述

给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。

注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s

返回一个表示每个字符串片段的长度的列表。

示例 1:

输入:s = "ababcbacadefegdehijhklij"
输出:[9,7,8]
解释:
划分结果为 "ababcbaca"、"defegde"、"hijhklij" 。
每个字母最多出现在一个片段中。
像 "ababcbacadefegde", "hijhklij" 这样的划分是错误的,因为划分的片段数较少。 

示例 2:

输入:s = "eccbbbbdec"
输出:[10]

提示:

  • 1 <= s.length <= 500
  • s 仅由小写英文字母组成

题解

根据题目要求,我们不难快速想到一个符合直觉的算法:在某个字母最后一次出现的地方分割,同时保证分割后的这一段中,其他字母也仅在这一段出现。

每个字母最后出现的位置容易解决,遍历一遍字符串、不断更新出现位置即可。而要保证分割后,其他字母也只在这段出现,则说明分割处的字母是这段子串里所有字母中,“最后出现位置”最靠后的的一个。所以我们只需要维护一个“当前出现的最后位置的最大值”即可,借用 代码随想录 中的图可以直观说明:

在这里插入图片描述

代码(C++)

vector<int> partitionLabels(string s)
{
    // 找到每个字母最后一次出现的位置
    unordered_map<char, int> lastOccur;
    for (int i = 0; i < s.size(); ++i)
        lastOccur[s[i]] = i;
    vector<int> res;
    int curCount = 0;
    int curLastPos = -1;
    for (int i = 0; i < s.size(); ++i) {
        curLastPos = max(curLastPos, lastOccur[s[i]]);
        curCount++;
        if (curLastPos == i) {
            res.push_back(curCount);
            curCount = 0;
        }   
    }
    return res;
}

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

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

相关文章

印刷企业实施数字工厂管理系统后能提升哪些效益

在当今这个数字化转型浪潮席卷全球的时代&#xff0c;印刷企业作为传统制造业的重要组成部分&#xff0c;正面临着前所未有的挑战与机遇。为了提升生产效率、降低成本、增强市场竞争力&#xff0c;越来越多的印刷企业开始引入数字工厂管理系统&#xff0c;这一举措不仅重塑了企…

Inno Setup根据系统的不同(32位/64位)安装不同的exe

注意事项 Inno Setup6.0及以上版本生成的可执行文件&#xff0c;可以运行在Windows7及以上系统&#xff0c;不支持WindowsXP系统。 如果要运行在WindowsXP系统上&#xff0c;需要下载Inno Setup6.0之前的版本。 Inno Setup 汉化版5.3.4下载链接&#xff1a; https://download…

从入门到精通:大学生编程技能提升全攻略

文章目录 每日一句正能量前言编程语言选择编程语言选择&#xff1a;为新手导航Python&#xff1a;初学者的友好伙伴JavaScript&#xff1a;Web开发的核心Java&#xff1a;企业级应用的经典C&#xff1a;系统编程的基石Ruby&#xff1a;优雅高效的编程Swift&#xff1a;iOS开发的…

OBS设置大揭秘:参数优化技巧与顶级录屏软件全攻略

在这个数字化的时代&#xff0c;屏幕录制已成为我们记录和分享知识、技能的重要手段。如果你还在为寻找一款既专业又易用的录屏软件而烦恼&#xff0c;那么今天的文章将为你揭开谜底。 录屏软件一、OBS studio OBS studio&#xff0c;作为录屏和直播领域的标杆&#xff0c;其功…

echarts图例旁边加百分比及百分比对齐

一、效果图 在这里插入图片描述 二、代码 import cirle from /assets/imgs/dataScree/ybp.pnglet option{tooltip: {trigger: item,formatter: function (params) {return }},legend: {orient: vertical, // 图例列表的布局朝向&#xff0c;horizontal为水平,vertical为垂直…

电话机器人能提升销售效率

经济敏捷发展的当天&#xff0c;任何行业都不离开市场&#xff0c;无法让更多人理解本人企业本人的产物。那样的话&#xff0c;像电话营销那样抢手的行业也面临很大的困难&#xff0c;员工不仅工作压力大&#xff0c;工作时间长&#xff0c;呼叫量多&#xff0c;还能忍受顾客的…

LangChain: Reduce size of tokens being passed to OpenAI

题意&#xff1a;在使用 LangChain时&#xff0c;需要减少传递给OpenAI的令牌&#xff08;tokens&#xff09;的数量 问题背景&#xff1a; I am using LangChain to create embeddings and then ask a question to those embeddings like so: 我正在使用 LangChain 来创建嵌…

记录|To run this application, you must install .NET Core.【C#,VS】

目录 前言一、问题描述二、解决办法三、.NET版本和Windows版本对接更新时间 前言 参考文章&#xff1a; 1、安装失败&#xff0c;提示“To run this application,you must install .netcore…” 2、【bug】to run this application ,you must install .net 3、在 Windows 上安装…

【亲测管用】Windows11 部署Maxkb + 本地Ollama

一、下载地址 maxkb&#xff1a;https://maxkb.cn/ ollama: https://ollama.com/download/windows 二、安装ollama 2.1 默认安装 直接install就好&#xff0c;默认是安装到C盘里面的。 安装好之后会显示在 直接打开cmd黑窗口&#xff0c;输入命令即可查看。 2.2 ollama…

什么牌子的洗地机好用?石头、添可、希亦真实使用测评对比!

随着科技的不断进步&#xff0c;许多人已经更新了家中的清洁工具。在挑选时&#xff0c;大家可能会看到很多网络攻略&#xff0c;但看得越多&#xff0c;反而越难抉择。其实&#xff0c;最直接的方法是看看这些工具的真实使用体验&#xff0c;这样就能大概知道自己使用时的感受…

5G 网络切片

5G 业务分类 增强型移动宽带(eMBB) 传统数据业务&#xff0c;特点是高带宽超高可靠性低时延业务&#xff08;URLLC&#xff09;无人驾驶、工业自动化等业务, 特点是高可靠、低时延海量机器类通信(mMTC) 物联网&#xff0c;特点是大量连接&#xff0c;时延不敏感&#xff0c;数…

练习2.19

先上代码吧。 (defn first-denomination [coin-values](first coin-values))(defn no-more? [coin-values](if (empty? coin-values) truefalse))(defn except-first-denomination [coin-values ](rest coin-values ))(defn cc[amount coin-values](cond ( amount 0) 1(or (…

ChatGPTAI指令提示工程案例

一、AI指令提示工程概述 AI指令提示工程&#xff08;AI Prompt Engineering&#xff09;是指通过设计巧妙的提示词&#xff08;Prompt&#xff09;来引导人工智能模型&#xff0c;特别是像ChatGPT这样的自然语言处理模型&#xff0c;生成符合用户需求的回答。这一过程不仅涉及…

重塑视界,流畅无界:『Levels of Detail』

在那片烽火连天的虚拟疆域——《刺激战场》中&#xff0c;你是否曾披荆斩棘&#xff0c;穿梭于一个个错落有致的城市迷宫&#xff1f;当我们飞越天际&#xff0c;俯瞰那些精心雕琢的城市场景&#xff0c;心中是否闪过一丝好奇的火花&#xff1a;在这广阔天地间&#xff0c;为何…

冷门细分才是王道,小白用AI几分钟生成,都有出了7000+单了

现在大家都在说&#xff0c;网上整点米&#xff0c;越来越难了&#xff0c;竞争太激烈。那要不看看冷门赛道&#xff0c;看这样冷门细分赛道&#xff0c;【绘本故事】&#xff0c;我视频号&#xff0c;和其他平台都搜了下&#xff0c;千赞&#xff0c;万赞很多。 这样的图片大家…

一文带你彻底搞定小程序分包和预加载

小程序分包 某些情况下&#xff0c;开发者需要将小程序划分成不同的子包&#xff0c;在构建时打包成不同的分包&#xff0c;用户在使用时按需进行加载。 在构建小程序分包项目时&#xff0c;构建会输出一个或多个分包。每个使用分包小程序必定含有一个主包。所谓的主包&#…

思码逸 信通院联合发布:《研发效能基准报告》解读

页数&#xff1a;47页 免费下载&#xff1a;https://fs80.cn/go7exq 本文共计6000字&#xff0c;建议阅读时间&#xff1a;5-10分钟。 阅读本文你将收获&#xff1a; 研发效能基准指标 研发效能基准指标数据&#xff1a;交付速率、交付质量、交付能力 研发效能综合分析&…

基于springboot+vue+uniapp的英语学习交流平台小程序

开发语言&#xff1a;Java框架&#xff1a;springbootuniappJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#…

视觉SLAM中的数学基础01 -3D空间的位置表示

在视觉SLAM中&#xff0c;理解和表示3D空间中的位置是至关重要的。这涉及到多种数学概念和工具&#xff0c;如坐标系、向量、矩阵、旋转和平移等。这些数学基础构成了视觉SLAM算法的核心。以下是3D空间位置表示的基本数学概念。 这是一个表示世界坐标系和相机坐标系之间关系的3…

以差异化运营高亮建材企业品牌优势,多层级孵化客户成交

建筑建材业作为国民经济的支柱产业之一,行业周期性明显,其发展情况与宏观经济走势高度相关。过去一年,随着供应链上下游的发展滑坡,建筑建材企业的流动性压力进一步显现,市场格局逐渐两级分化,头部企业甚至能在出口旺季一举收割将近80%的盈利份额。 对于非集团性门窗企业来说,…