算法刷题记录 Day31

2024-04-02 17:36
文章标签 算法 记录 刷题 day31

本文主要是介绍算法刷题记录 Day31,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

算法刷题记录 Day31

Date: 2024.03.27

lc 56. 合并区间

class Solution {
public:static bool cmp(vector<int>& a, vector<int>& b){if(a[0] != b[0])return a[0] < b[0];elsereturn a[1] > b[1];}vector<vector<int>> merge(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end(), cmp);vector<vector<int>> res;// 1.遍历过程中,若遇到start小于上一个的end,则合并。start不变,end变为两者的最大值。int start = intervals[0][0];int end = intervals[0][1];for(int i=1; i<intervals.size(); i++){if(intervals[i][0] <= end){end = max(intervals[i][1], end);}else{res.push_back(vector<int>{start, end});start = intervals[i][0];end = intervals[i][1];}}res.push_back(vector<int>{start, end}); //  补上最后一个区间return res;}
};
  1. 划分字母区间
class Solution {
public:vector<int> partitionLabels(string s) {vector<int> res;int n = s.size();vector<int> dict(26, -1);    //保存s中各字符出现的最后索引.不存在则为-1.for(int i=0; i<n; i++){dict[s[i] - 'a'] = i;}// 根据每个字符的最后出现索引,判断所需的长度int start = 0;int end = 0;int before_end = 0;while(end < s.size()){int max_next_end = INT_MIN;for(int i=before_end; i<=end; i++){max_next_end = max(max_next_end, dict[s[i] - 'a']);}if(end == max_next_end){    //一轮迭代后end不变,则该长度符合要求res.push_back(end-start+1);start = end+1;end = start;before_end = start;}else{before_end = end;end = max_next_end;}}return res;}
};
  1. 无重叠区间
class Solution {
public:static bool cmp(vector<int>& a, vector<int>& b){if(a[0] != b[0])return a[0] < b[0];else{return a[1] < b[1];}}int eraseOverlapIntervals(vector<vector<int>>& intervals) {sort(intervals.begin(), intervals.end(), cmp);// int cur_start = intervals[0][0];int cur_end = intervals[0][1];int cut_nums = 0;for(int i=1; i<intervals.size(); i++){if(intervals[i][0] < cur_end){if(intervals[i][1] < cur_end){  //如果是真子集,则舍去大的,保留小的cur_end = intervals[i][1];}cut_nums++;}else{cur_end = intervals[i][1];}}return cut_nums;}
};

这篇关于算法刷题记录 Day31的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio