算法训练营第三十八天 | LeetCode 435 无重叠区间、LeetCode 763 划分字母区间、LeetCode 56 合并区间

本文主要是介绍算法训练营第三十八天 | LeetCode 435 无重叠区间、LeetCode 763 划分字母区间、LeetCode 56 合并区间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LeetCode 435 无重叠区间

这题和用最少数量的🗡引爆气球比较相像,首先还是要对区间进行排序,至于按左边界还是按右边界好像无所谓。但是上一题我用的是左边界排序,对右边界进行更新,所以这里我们就还是采用一样的思路好了。

大概也还是双指针,并且每次循环开始将j固定在i+1位置开始遍历,如果j起始位置小于i结束位置,注意是小于,这里是重叠,不包含挨在一起的情况,就将需要去重叠的区间数+1,并且更新下最小左边界。之后更新下j的下标和i的下标即可。这里其实写得有些啰嗦了,可以再改进下,用递归遍历的思维去写,这里就不专门写了,可以去看看本体题解吧。

class Solution {public int eraseOverlapIntervals(int[][] intervals) {Arrays.sort(intervals, (a,b)->Integer.compare(a[0], b[0]));int sum = 0;int j = 0;for (int i = 0; i < intervals.length; i++) {j = i + 1;while (j < intervals.length && intervals[j][0] < intervals[i][1]) {intervals[i][1] = Math.min(intervals[j][1], intervals[i][1]);sum++;j++; }if (j < intervals.length) {i = j - 1;}else break;}return sum;}
}

LeetCode 763 划分字母区间

这题其实用到一种新的思路,也可以用之前的思路,但是涉及到可能有字母没出现的问题,所以现就还是用原本的思路来吧。

大概就是先把每个出现字母的最后一个位置记录下。第二次一重遍历的时候,用一个变量记录当前出现字母最远结束位置,如果这个位置等于当前的i,就可以直接放入列表中了。这样一直到最后一个元素,就可以很好地解决这个问题了。

需要注意下java里面String访问起来要用到charAt,所以我们可以用toCharArray函数将它转化成字符数组来处理,会和C++里面一样好用。

代码如下:

class Solution {public List<Integer> partitionLabels(String s) {List<Integer> ans = new LinkedList<>();int[] last = new int[26];char[] c = s.toCharArray();for (int i = 0; i < c.length; i++) {last[c[i] - 'a'] = i;}int index = 0;int start = 0;for (int i = 0; i < c.length; i++) {index = Math.max(index, last[c[i] - 'a']);if (index == i) {ans.add(index - start + 1);start = index + 1;}}return ans;}
}

LeetCode 56 合并区间

这题用的就是我上一题没用上的思路,就是先排序后比较,比较的是两个相邻区间中左区间右边界和右区间左边界之间是否重叠,有的话就将第二个区间左边界更新成两个区间中较小的左边界,将右边界更新成两个区间中较大的右边界,遇到当前区间已经是最后一个区间或者下一个区间不相邻的情况就直接将当前区间入向量即可。

C++代码如下:

class Solution {
public:vector<vector<int>> merge(vector<vector<int>>& intervals) {if (intervals.size() == 0) {return {};}sort(intervals.begin(), intervals.end());vector<vector<int>> res;for (int i = 0; i < intervals.size(); i++) {if (i + 1 < intervals.size() && intervals[i + 1][0] <= intervals[i][1]) {intervals[i + 1][1] = max(intervals[i + 1][1], intervals[i][1]);intervals[i + 1][0] = min(intervals[i + 1][0], intervals[i][0]);} else {res.push_back(intervals[i]);}}return res;}
};

java代码如下:

class Solution {public int[][] merge(int[][] intervals) {List<int[]> res = new LinkedList<>();Arrays.sort(intervals, (a,b)->Integer.compare(a[0], b[0]));for (int i = 0; i < intervals.length; i++) {if (i + 1 < intervals.length && intervals[i + 1][0] <= intervals[i][1]) {intervals[i + 1][0] = Math.min(intervals[i + 1][0], intervals[i][0]);intervals[i + 1][1] = Math.max(intervals[i + 1][1], intervals[i][1]);} else {res.add(intervals[i]);}}return res.toArray(new int[res.size()][]);}
}

这篇关于算法训练营第三十八天 | LeetCode 435 无重叠区间、LeetCode 763 划分字母区间、LeetCode 56 合并区间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述。以下是从不同角度对气象站的种类和应用范围的介绍: 一、气象站的种类 根据用途和安装环境分类: 农业气象站:专为农业生产服务,监测土壤温度、湿度等参数,为农业生产提供科学依据。交通气象站:用于公路、铁路、机场等交通场所的气象监测,提供实时气象数据以支持交通运营和调度。林业气象站:监测林区风速、湿度、温度等气象要素,为林区保护和

大林 PID 算法

Dahlin PID算法是一种用于控制和调节系统的比例积分延迟算法。以下是一个简单的C语言实现示例: #include <stdio.h>// DALIN PID 结构体定义typedef struct {float SetPoint; // 设定点float Proportion; // 比例float Integral; // 积分float Derivative; // 微分flo

LeetCode--231 2的幂

题目 给定一个整数,编写一个函数来判断它是否是 2 的幂次方。 示例 示例 1:输入: 1输出: true解释: 20 = 1示例 2:输入: 16输出: true解释: 24 = 16示例 3:输入: 218输出: false class Solution {public:bool isPowerOfTwo(int n) {if (n <= 0) return fals

LeetCode--234 回文链表

题目 请判断一个链表是否为回文链表。 示例 示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val

LeetCode--220 存在重复元素 III

题目 给定一个整数数组,判断数组中是否有两个不同的索引 i 和 j,使得 nums [i] 和 nums [j] 的差的绝对值最大为 t,并且 i 和 j 之间的差的绝对值最大为 ķ。 示例 示例 1:输入: nums = [1,2,3,1], k = 3, t = 0输出: true示例 2:输入: nums = [1,0,1,1], k = 1, t = 2输出: true示例

LeetCode--217 存在重复元素

题目 给定一个整数数组,判断是否存在重复元素。如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。 示例 示例 1:输入: [1,2,3,1]输出: true示例 2:输入: [1,2,3,4]输出: false示例 3:输入: [1,1,1,3,3,4,3,2,4,2]输出: true class Solution {p

LeetCode--214 最短回文串

题目 给定一个字符串 s,你可以通过在字符串前面添加字符将其转换为回文串。找到并返回可以用这种方式转换的最短回文串。 示例 示例 1:输入: "aacecaaa"输出: "aaacecaaa"示例 2:输入: "abcd"输出: "dcbabcd" 思路: 我们需要添加多少个字符与给定字符串的前缀子串回文的长度有关. 也就是说去掉其前缀的回文子串,我们只需要补充剩下的子串的逆序

LeetCode--206 反转链表

题目 反转一个单链表。 示例 示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL class Solution {public:ListNode* reverseList(ListNode* head) {if (head == nullptr || head->next == nullptr){return head;}ListNo