【算法训练记录——Day36】

Day36——贪心Ⅳ

  • 1.leetcode_452用最少数量的箭引爆气球
  • 2.leetcode_435无重叠区间
  • 3.leetcode_763划分字母区间
  • 4.leetcode_

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

在这里插入图片描述
思路:看了眼题解,局部最优:当气球出现重叠,一起射,所用弓箭最少。全局最优:把所有气球射爆所用弓箭最少。如果真实的模拟射气球的过程,应该射一个,气球数组就remove一个元素,这样最直观,毕竟气球被射了。

但仔细思考一下就发现:如果把气球排序之后,从前到后遍历气球,被射过的气球仅仅跳过就行了,没有必要让气球数组remove气球,只要记录一下箭的数量就可以了。

	int findMinArrowShots(vector<vector<int>>& points) {int res = 1;sort(points.begin(), points.end());int preRight(points[0][1]);// for(auto i : points) {//     cout << i[0] << " " << i[1] << endl;// }// cout << "==========" << endl;for(int i = 1; i < points.size(); i++) {// cout << i << " " << preRight << endl;if(preRight < points[i][0]) {res++;preRight = points[i][1];} else {preRight = min(preRight, points[i][1]);}}return res;}

主要思路是每次都维护当前交集最小的边界,因为已经拍过序了。如果不相交,res++,然后更新当前位置能覆盖的最大边界,如果相交,就更新最小边界。和题解解法差不多

2.leetcode_435无重叠区间

在这里插入图片描述
思路:
怎么看是否重叠?同样还是排序,看是否相交(left > right)
2. 有重叠移除哪个?移除右边界大的那个

	static bool cmp(const vector<int>& v1, const vector<int>& v2) {if(v1[0] == v2[0]) return v1[1] < v2[1];return v1[0] < v2[0];}
public:int eraseOverlapIntervals(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end(), cmp);// for(auto i : intervals)//     cout << i[0] << " " << i[1] << endl;int res = 0;int preRight = intervals[0][1];for(int i = 1; i < intervals.size(); i++) {if(intervals[i][0] < preRight) {preRight = min(preRight, intervals[i][1]); // 有重叠移除大边界res++;} else {preRight = intervals[i][1]; // 无重叠更新边界}}return res;}

看了眼题解,思路差不多,我这里选用左边界排序

3.leetcode_763划分字母区间

在这里插入图片描述
思路:整体思路和前两题差不多,区别在于,需要做转换。将同一字母划分在同一片段,遍历一次数组,保存字母出现的开始位置和结束位置,记录首字母位置信息,对保存的字母位置信息进行排序(排序是为了让开始位置连续,以便记录交集),若pre 和 cur 不相交,将之前的位置信息加入res中,更新新的左边界和右边界;相交,则更新边界

	static bool cmp(const vector<int>& v1, const vector<int>& v2) {if(v1[0] == v2[0]) return v1[1] < v2[1];return v1[0] < v2[0];}
public:vector<int> partitionLabels(string s) {vector<vector<int>> dp = {26, vector<int>{0, 0}};for(int i = 0; i < s.size(); i++) {int index = s[i]-'a';if(dp[index][0] == dp[index][1]) {dp[index][0] = i + 1;} else {dp[index][1] = i + 1;}}int preLeft = dp[s[0]-'a'][0];int preRight = dp[s[0]-'a'][1];sort(dp.begin(), dp.end(), cmp);vector<int> res;if(preRight == 0) preRight = preLeft;for(int i = 1; i < 26; i++) {if(dp[i][0] != 0) {if(dp[i][1] == 0) dp[i][1] = dp[i][0];// cout << (char)('a' + i) << " " << dp[i][0] << " " << dp[i][1] << endl;if(preRight >= dp[i][0]) {preRight = max(preRight, dp[i][1]);} else {// cout << "  " << preRight << " " << preLeft << endl;res.push_back(preRight - preLeft + 1);preLeft = dp[i][0];preRight = dp[i][1];}}}res.push_back(preRight - preLeft + 1);return res;}

看了下题解,还有另一种方法:
每一个字母都有其最远出现位置,如果在一个区间内,当前位置等于所有字母最远出现位置,那么说明到达了分界点,即可写出如下代码

	vector<int> partitionLabels(string s) {vector<int> res;int hash[26] = {0};for(int i = 0; i < s.size(); i++) {// hash[s[i]-'a'] = max(hash[s[i]-'a'], i);hash[s[i]-'a'] = i; // 记录最远位置}int right = 0; // 记录当前区间最远位置int left = 0;for(int i = 0; i < s.size(); i++) {right = max(right, hash[s[i] - 'a']); // 更新最远位置if(i == right) {	// 到达最远位置res.push_back(right - left + 1);left = right + 1;	}	}return res;}

4.leetcode_

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

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

相关文章

快速了解GPT-4o和GPT-4区别

GPT-4o简介 在5月14日的OpenAI举行春季发布会上&#xff0c;OpenAI在活动中发布了新旗舰模型“GPT-4o”&#xff01;据OpenAI首席技术官穆里穆拉蒂&#xff08;Muri Murati&#xff09;介绍&#xff0c;GPT-4o在继承GPT-4强大智能的同时&#xff0c;进一步提升了文本、图像及语…

Tesseract Python 图片文字识别入门

1、安装tesseract Index of /tesseract https://digi.bib.uni-mannheim.de/tesseract/tesseract-ocr-w64-setup-v5.3.0.20221214.exe 2、安装中文语言包 https://digi.bib.uni-mannheim.de/tesseract/tessdata_fast/ 拷贝到C:\Program Files\Tesseract-OCR\tessdata 3、注…

昇思25天学习打卡营第3天|数据集全攻略:加载、操作与自定义

导入数据集相关库和类 首先&#xff0c;导入了 NumPy 库&#xff0c;并将其简称为 np 。要知道&#xff0c;NumPy 乃是用于科学计算的关键库&#xff0c;作用非凡。接着&#xff0c;从 mindspore.dataset 当中导入了 vision 模块。此外&#xff0c;还从 mindspore.dataset 里引…

前后端分离的后台管理系统开发模板(带你从零开发一套自己的若依框架)上

前言&#xff1a; 目前&#xff0c;前后端分离开发已经成为当前web开发的主流。目前最流行的技术选型是前端vue3后端的spring boot3&#xff0c;本次。就基于这两个市面上主流的框架来开发出一套基本的后台管理系统的模板&#xff0c;以便于我们今后的开发。 前端使用vue3ele…

Web前端

网页开发学习内容:html css JavaScript 两个框架:VUE.js ElementUI UI->user interface 用户界面 html(HyperText Markup Language):超文本标记语言 文本:文字 字符 超文本:网页内容 标记:标签 标识 例如商品上的标签,介绍了商品的信息 html语言就是一种标记语言,提供…

AWS云中的VPC启用流日志保存S3(AWS中国云)

问题 需要在AWS中国云中对VPC启用流日志操作。 步骤 创建s3桶 这里设置一个s3桶名&#xff0c;创建即可。如果出现已存在具有相同名称的存储桶错误&#xff0c;就换个桶名再试一试吧。 启用vpc流日志 找到vpc流日志入口操作&#xff0c;如下图&#xff1a; 设置vpc流日志…

eBPF技术揭秘:DeepFlow如何引领故障排查,提升运维效率

DeepFlow 实战&#xff1a;eBPF 技术如何提升故障排查效率 目录 DeepFlow 实战&#xff1a;eBPF 技术如何提升故障排查效率 微服务架构系统中各个服务、组件及其相互关系的全景 零侵扰分布式追踪&#xff08;Distributed Tracing&#xff09;的架构和工作流程 关于零侵扰持…

任务5.1 初识Spark Streaming

实战概述&#xff1a;使用Spark Streaming进行词频统计 1. 项目背景与目标 背景: Spark Streaming是Apache Spark的流处理框架&#xff0c;用于构建可伸缩、高吞吐量的实时数据处理应用。目标: 实现一个实时词频统计系统&#xff0c;能够处理流式数据并统计文本中的单词出现频…

微机原理 复习

第一章导论 1.3 冯诺依曼体系结构 &#xff08;1&#xff09;以二进制形式表示指令和数据 &#xff08;2&#xff09;程序和数据事先放在存储器中&#xff08;预存储&#xff09; &#xff08;3&#xff09;由运算器、控制器、输入设备和输出设备五大部件组成 字长、主频…

Java8新特性stream的原理和使用

这是一种流式惰性计算&#xff0c;整体过程是&#xff1a; stream的使用也异常方便&#xff0c;可以对比如List、Set之类的对象进行流式计算&#xff0c;挑出最终想要的结果&#xff1a; List<Timestamp> laterTimes allRecords.stream().map(Record::getTime).filter…

【摄像头标定】双目摄像头标定及矫正-opencv(python)

双目摄像头标定及矫正 棋盘格标定板标定矫正 棋盘格标定板 本文使用棋盘格标定板&#xff0c;可以到这篇博客中下载&#xff1a;https://blog.csdn.net/qq_39330520/article/details/107864568 标定 要进行标定首先需要双目拍的棋盘格图片&#xff0c;20张左右&#xff0c;…

30 哈希的应用

位图 概念 题目 给40亿个不重复的无符号整数&#xff0c;没排过序。给一个无符号整数&#xff0c;如何判断一个数是否在这40亿个整数中 1.遍历&#xff0c;时间复杂度O(N) 2.二分查找&#xff0c;需要先排序&#xff0c;排序(N*logN)&#xff0c;二分查找&#xff0c;logN。…

装载问题(回溯法)

#include<iostream> using namespace std; int n;//货物的数量 int c;//轮船的总的载重量 int cw;//轮船当前的载重量 int r;//货物的总重量 int w[1000];//n个货物各自的重量 int x[1000];//当前最优解 int bestx[1000];//最优解 int bestw;//货物的最优载重量 void Bac…

[JS]对象

介绍 对象是一种无序的数据集合, 可以详细的描述某个事物 事物的特征在对象中用属性来表示, 事物的行为在对象中用方法来表示 使用 创建对象 let 对象名 {属性名&#xff1a;值&#xff0c;方法名&#xff1a;函数&#xff0c; } let 对象名 new Object(); 对象名.属性…

Typora failed to export as pdf. undefined

变换版本并没有用&#xff0c;调整图片大小没有用 我看到一个博客后尝试出方案 我的方法 解决&#xff1a;从上图中的A4&#xff0c;变为其他&#xff0c;然后变回A4 然后到处成功&#xff0c;Amazing&#xff01; 参考&#xff1a; Typora 导出PDF 报错 failed to export…

Rpc服务的提供方(Rpcprovider)的调用流程

首先&#xff0c;服务的提供方&#xff0c;会通过rpcprovider向rpc服务方注册rpc服务对象和服务方法&#xff0c; 那么&#xff0c;我们通过protobuf提供的抽象层的service和method&#xff0c;将服务对象和它所对应的服务方法记录在map表中&#xff0c; 当它启动以后&#xff…

WordPress Quiz Maker插件 SQL注入漏洞复现(CVE-2024-6028)

0x01 产品简介 WordPress Quiz Maker插件是一款功能强大的测验生成工具,旨在帮助用户轻松、快速地构建复杂的测验和考试。插件支持多种问题类型,包括单选框(MCQ)、复选框(MCQ)、下拉列表(MCQ)、文本、短文本、数字、日期等。还支持横幅(HTML)显示信息性消息、填空题…

LONGAGENT:优化大模型处理长文本

现有的大模型&#xff08;LLMs&#xff09;&#xff0c;尽管在语言理解和复杂推理任务上取得了显著进展&#xff0c;但在处理这些超长文本时却常常力不从心。它们在面对超过10万令牌的文本输入时&#xff0c;常常会出现性能严重下降的问题&#xff0c;这被称为“中间丢失”现象…

Docker基本使用和认识

目录 基本使用 镜像仓库 镜像操作 Docker 如何实现镜像 1) namespace 2) cgroup 3) LXC Docker常见的网络类型 bridge网络如何实现 基本使用 镜像仓库 镜像仓库登录 1)docker login 后面不指定IP地址&#xff0c;则默认登录到 docker hub 上 退出 2)docker logo…

互联网直播/点播技术与平台创新应用:视频推拉流EasyDSS案例分析

随着互联网技术的快速发展&#xff0c;直播/点播平台已成为信息传播和娱乐的重要载体。特别是在电视购物领域&#xff0c;互联网直播/点播平台与技术的应用&#xff0c;不仅为用户带来了全新的购物体验&#xff0c;也为商家提供了更广阔的营销渠道。传统媒体再一次切实感受到了…