算法闭关修炼百题计划(四)

仅供个人复习

  • 1.两数相加
  • 2.寻找峰值
  • 3.寻找旋转排序数组中的最小值
  • 4.寻找旋转排序数组中的最小值II
  • 5.搜索旋转排序数组
  • 6.岛屿的最大面积
  • 7.最大数
  • 8.会议室
  • 9.最长连续序列

1.两数相加

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

/*
因为两个链表都是逆序,相当于个位数在最前面,所以可以直接相加,多余的十位数、百位数 用 temp 记录下来,加到下一个节点
*/
class Solution {
public:ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {//构建新链表的头节点和尾节点ListNode* head = nullptr;ListNode* tail = nullptr;int tmp = 0; //相加的进位,比如7+8=15,tmp=1while (l1 != nullptr || l2 != nullptr) {int val1 = l1 != nullptr ? l1->val : 0; // l1不为空,取节点的值,为空则取0int val2 = l2 != nullptr ? l2->val : 0;int sum = val1 + val2 + tmp;// 往相加的链表后拼接节点if (head == nullptr) {head = new ListNode(sum % 10);tail = head;} else {tail->next = new ListNode(sum % 10);tail = tail->next;}tmp = sum / 10; //除了个位数,剩下的是进位,放入tmpif (l1 != nullptr) l1 = l1->next;if (l2 != nullptr) l2 = l2->next;}//最后如果 tmp ≠ 0,说明还有进位,需要一个节点存放if (tmp > 0) tail->next = new ListNode(tmp);return head;}
};

2.寻找峰值

峰值元素是指其值严格大于左右相邻值的元素。

给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。

你可以假设 nums[-1] = nums[n] = -∞ 。

你必须实现时间复杂度为 O(log n) 的算法来解决此问题。

二分法,注意mid+1可能越界

class Solution {
public:int findPeakElement(vector<int>& nums) {int L = -1, R = nums.size();if(nums.size() == 1) return 0;while(L + 1 != R){int mid = (L + R) / 2;if(mid == nums.size() - 1){R = nums.size() - 1;break;}if(nums[mid] > nums[mid + 1]) R = mid;else L = mid;}return R;}
};

3.寻找旋转排序数组中的最小值

按照二分法的模板,right = nums.size(),但是这里必须是right = nums.size() - 1.
我还没明白

class Solution {
public:int findMin(vector<int>& nums) {int left = -1, right = nums.size() - 1;while(left + 1 != right){int mid = (left + right) / 2;if(nums[mid] < nums.back()) right = mid;else left = mid;}return nums[right];}
};

4.寻找旋转排序数组中的最小值II

可能存在 重复 元素值的数组 nums !!!

class Solution {
public:int findMin(vector<int> &nums) {int left = -1, right = nums.size() - 1; // 开区间 (-1, n-1)while (left + 1 < right) { // 开区间不为空int mid = left + (right - left) / 2;if (nums[mid] < nums[right]) right = mid; // 蓝色else if (nums[mid] > nums[right]) left = mid; // 红色else --right;}return nums[right];}
};

5.搜索旋转排序数组

整数数组 nums 按升序排列,数组中的值 互不相同 。
在某个点旋转之后,找target下标

class Solution {
public:int findMin(vector<int>& nums){int left = -1, right = nums.size() - 1;while(left + 1 != right){int mid = (right + left) / 2;if(nums[mid] < nums.back()) right = mid;else left = mid;}return right;}int lower_bound(vector<int>& nums, int left, int right, int target){while(left + 1 != right){int mid = (left + right) / 2;if(nums[mid] < target) left = mid;else right = mid;}if(right == nums.size()) return -1;return nums[right] == target ? right : -1;}int search(vector<int>& nums, int target) {int index = findMin(nums);if(target > nums.back()){int ans = lower_bound(nums, -1, index, target);return ans;}return lower_bound(nums, index - 1, nums.size(), target);}
};

6.岛屿的最大面积

class Solution {
public:int dir[4][2] = {-1, 0, 0, -1, 1, 0, 0, 1};int count;void dfs(vector<vector<int>>& grid, vector<vector<bool>>& visited, int x, int y){for(int i = 0; i < 4; i ++){int nextx = x + dir[i][0];int nexty = y + dir[i][1];if(nextx < 0 || nextx >= grid.size() || nexty < 0 || nexty >= grid[0].size()) continue;if(!visited[nextx][nexty] && grid[nextx][nexty] == 1){visited[nextx][nexty] = true;count++;dfs(grid, visited, nextx, nexty);}}}int maxAreaOfIsland(vector<vector<int>>& grid) {int res = 0;vector<vector<bool>> visited(grid.size(), vector<bool>(grid[0].size(), false));for(int i = 0; i < grid.size(); i ++){for(int j = 0; j < grid[0].size(); j ++){if(grid[i][j] == 1 && !visited[i][j]){count = 1;//每个岛屿重置countvisited[i][j] = true;dfs(grid, visited, i, j);res = max(res, count);}}}return res;}};

7.最大数

给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。

注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。

class Solution {
public:string largestNumber(vector<int>& nums) {vector<string> str;for(auto i : nums){str.push_back(to_string(i));}auto cmp = [](string left, string right){return left + right > right + left;};sort(str.begin(), str.end(), cmp);string ans = "";for(auto c : str){ans += c;}if(ans[0] == '0') return "0";return ans;}
};

8.会议室

给你一个会议时间安排的数组 intervals ,每个会议时间都会包括开始和结束的时间 intervals[i] = [starti, endi] ,返回 所需会议室的最小数量 。

输入:intervals = [[0,30],[5,10],[15,20]]
输出:2

可以把他理解为上车下车问题
同时在车上最多人数就是需要的会议室数量
在这里插入图片描述
挺巧的这个做法

class Solution {
public:int minMeetingRooms(vector<vector<int>>& intervals) {map<int, int> umap;for(auto it : intervals){umap[it[0]]++;umap[it[1]]--;}int ans = 0, cnt = 0;for(auto itt : umap){cnt += itt.second;ans = max(ans, cnt);}return ans;}
};

用map而不是unordered_map,因为键值对在map中是有序的,即元素按照键的升序排列。用他才能用上车下车的写法。

9.最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

class Solution {
public:int longestConsecutive(vector<int>& nums) {unordered_set<int> set(nums.begin(), nums.end());int res = 0;for(int num : set){if(set.find(num - 1) != set.end()) continue;//不是第一个就跳过,因为我们要找第一个int curNum = num;int curLen = 1;while(set.find(curNum + 1) != set.end()){curNum += 1;curLen += 1;}res = max(res, curLen);}return res;}
};

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

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

相关文章

STM32 通用同步/异步通信

一、串行通信简介 CPU与外围设备之间的信息交换称为通信。基本的通信方式有并行通信和串行通信两种。STM32单片机提供了功能强大的串行通信模块&#xff0c;即通用同步/异步收发器&#xff08;USART&#xff09;。 1.串行通信 串行通信是数据字节一位一位地依次传送的通信方式。…

毕业设计 深度学习水果识别

文章目录 1 前言2 开发简介3 识别原理3.1 传统图像识别原理3.2 深度学习水果识别 4 数据集5 部分关键代码5.1 处理训练集的数据结构5.2 模型网络结构5.3 训练模型 6 识别效果 1 前言 Hi&#xff0c;大家好&#xff0c;这里是丹成学长&#xff0c;今天做一个 基于深度学习的水果…

毕业设计——医院信息化系统原型设计

作品详情 主要功能&#xff1a; 信息化系统是以患者为中心&#xff0c;服务于重症科室医务人员&#xff0c;提高工作效率及医疗服务质量。软件主要包含了重症医学临床管理系统和中央监控站&#xff0c;重症医学临床管理系统主要实现患者床位总览、患者护理、医嘱管理、数据字典…

JS 介绍/书写位置/输入输出语法

目录 1. JS 介绍 1.1 JS 是什么 1.2 JS 的作用 1.3 JS 的组成 2. JS 书写位置 2.1 内部 JS 2.2 外部 JS 2.3 内联 JS 3. JS 注释和结束符 4. JS 输入输出语法 4.1 输入语法 4.2 输入语句 4.3 执行顺序 5. 字面量 1. JS 介绍 1.1 JS 是什么 1.2 JS 的作用 1.3 JS …

GOM引擎启动后M2提示Invalid filename报错的解决办法

在架设一个GOM引擎版本的时候&#xff0c;启动M2就提示Invalid filename&#xff0c;之后的网关就没有办法再启动了&#xff0c;研究了半天也终于是弄好了&#xff0c;其实也简单&#xff0c;就是路径设置的不对&#xff0c;所以无法完成启动&#xff0c;很多人以为在控制台设置…

国庆节刷题

10.1 C语言 10.1 C 10.2 C语言 10.2 C 10.3 C语言 10.3 C 10.4 C语言 10.4 C 10.5 C语言 10.5 C 10.6 C语言 10.6 C

如何写出Pythonic的代码?

f-string、三元操作、各种解析式、生成器装饰器的熟练运用&#xff0c;“内库”引用和函数封装再加持PEP8&#xff0c;撰写的脚本不pythonic都难。&#x1f60e; (笔记模板由python脚本于2024年10月07日 18:03:27创建&#xff0c;本篇笔记适合特别喜欢python的coder翻阅) 【学习…

手机号归属地查询-手机号归属地-手机号归属地-运营商归属地查询-手机号码归属地查询手机号归属地-运营商归属地

手机号归属地查询API接口是一种网络服务接口&#xff0c;允许开发者通过编程方式查询手机号码的注册地信息。关于快证签API接口提供的手机号归属地查询服务&#xff0c;以下是一些关键信息&#xff1a; 一、快证签API接口简介 快证签API接口可能是一个提供多种验证和查询服务…

Burp Suite为何能抓到HTTPS的明文流量,Wireshark可以吗,公司电脑的加密流量也是被监控了吗?

在前期博文《万字图文详解HTTPS协议通信过程&#xff0c;结合抓包实战解析带你一次看透HTTPS&#xff01;》中&#xff0c;我们知悉HTTPS通信内容是用会话密钥加密的&#xff0c;但不少细心的读者存在疑问&#xff1a;为何对于使用HTTPS协议的站点&#xff0c;在Burp Suite中拦…

Excel-查找和引用数据-VLOOKUP 和 HLOOKUP 函数

在 Excel 中&#xff0c;VLOOKUP 和 HLOOKUP 是用于查找和引用数据的函数。下面是它们的基本用法&#xff1a; VLOOKUP 用途&#xff1a;在表格的第一列中查找某个值&#xff0c;并返回该值所在行的指定列中的数据。 语法&#xff1a; VLOOKUP(lookup_value, table_array, …

helm 测试卸载或删除(redis)

作者&#xff1a;程序那点事儿 日期&#xff1a;2024/02/07 18:30 查看redis 集群实例 kubectl get all -n redis 卸载集群实例 helm uninstall redis -n redis 删除pvc kubectl get pvc -n redis kubectl delete pvc redis-data-redis-master-0 redis-data-redis-replicas…

【Kubernetes】常见面试题汇总(五十九)

目录 129.问题&#xff1a;pod 使用 PV 后&#xff0c;无法访问其内容&#xff1f; 130.查看节点状态失败&#xff1f; 特别说明&#xff1a; 题目 1-68 属于【Kubernetes】的常规概念题&#xff0c;即 “ 汇总&#xff08;一&#xff09;~&#xff08;二十二&#xf…

Spring Cloud Netflix Ribbon 负载均衡详解和案例示范

1. 引言 在传统的集中式架构中&#xff0c;负载均衡器一般是放置在服务器端的&#xff0c;例如 Nginx等。随着微服务架构的兴起&#xff0c;服务实例的数量和部署地点变得更加动态和分布式&#xff0c;这使得在客户端进行负载均衡成为了一种可行且更灵活的方案。Netflix Ribbo…

Thinkphp/Laravel基于vue的金融理财产品销售系统设计与实现Vscode毕业设计成品源码.

目录 技术栈和环境说明具体实现截图设计思路关键技术课题的重点和难点&#xff1a;框架介绍数据访问方式PHP核心代码部分展示代码目录结构解析系统测试详细视频演示源码获取 技术栈和环境说明 采用PHP语言开发&#xff0c;开发环境为phpstudy 开发工具notepad并使用MYSQL数据库…

攻防世界 告诉你个秘密

前言&#xff1a;做题笔记。 下载 挺懵是不是。 仔细看&#xff0c;数字组合居多 字母不超过E 大概可以猜测这是16进制。 一开始以为是16进制转2进制的莫斯&#xff0c;但&#xff0c;&#xff0c;并不是。 试着将16进制转成ASCII字符。 别的不说&#xff0c;base64 老客户了…

Centos7 NTP客户端

目录 1. NTP客户端1.1 安装1.2 启动1.3 同步状态异常1.4 更改/etc/chrony.conf配置文件1.5 同步状态正常 1. NTP客户端 1.1 安装 如果chrony没有安装&#xff0c;可以使用以下命令安装 sudo yum install chrony1.2 启动 启动并设置开机自启 sudo systemctl start chronyd …

如何使用 Python 的 logging 模块记录日志

如何使用 Python 的 logging 模块记录日志 在编写 Python 程序时&#xff0c;日志记录是一个非常重要的部分。日志不仅帮助你在开发过程中调试代码&#xff0c;还可以在程序正式运行时提供诊断信息&#xff0c;帮助定位问题。如果你正在构建一个复杂的系统或者开发大型应用程序…

SLMA-雷达点如何转变为range image图像以及range image图像和球坐标系的关系;IROS 2020 REMOVERT动态SLAM论文解析

文章目录 雷达点如何转变到range image图像球体坐标关联 雷达点如何转变到range image图像 使用激光雷达采样得到的点一般包含x y z 坐标以及intensity、time、ring属性。参考如下&#xff1a; namespace velodyne_ros {struct EIGEN_ALIGN16 Point {PCL_ADD_POINT4D;float i…

多维放缩(MDS)与主成分分析(PCA)

文章目录 摘要Abstract1. 多维缩放&#xff08;MDS&#xff09;1.1 MDS降维条件1.2 MDS降维步骤 2. 主成分分析(PCA)2.1 最近重构性2.2 最大可分性2.3 PCA维度分析2.4 PCA实战2.5 PCA小结 3. 总结 摘要 多维缩放&#xff08;MDS&#xff09;是一种保持样本间距离关系的降维技术…

点餐小程序实战教程16餐厅管理

目录 1 创建数据源2 创建后台功能3 集成腾讯地图4 配置表单信息总结 在我们点餐小程序首页里&#xff0c;一开始会根据用户的位置信息去推荐餐厅&#xff0c;这就要求事先维护好餐厅的信息&#xff0c;本篇我们介绍一下餐厅信息的管理功能。 1 创建数据源 打开我们的数据模型&…