LeetCode数组刷题——448、48、240、769
1.【LeetCode448】:448. 找到所有数组中消失的数字
题目分析: 1-n之间有重复的,有没出现的,有出现一次。使用hashmap,空间复杂度为O(n)
方法一:哈希表,但是空间复杂度超过了O(n)
思想:
- 可以用hashmap存储数据,建立映射。
- 从1-n去遍历,看hashmap中有没有出现元素。
- 有出现,下一个继续遍历,没有传入数组。
方法二: 使用数组本身,这样空间就不会多用
思想:
- 已知元素的范围是1-n,数组下标的范围是0-n-1。从头开始遍历,比如说4,把它转换为对应的下标就是3,把3下标对应的元素变为负数(或者加n),这样就相当于 标记 与下标3对应的数。
- 如果某个数我们已经处理过了,这时候就要还原,然后再比较。
- 最后再遍历一次,找出没出现过的下标。
示例:
|
4 3 2 7 8 2 3 1
0 1 2 3 4 5 6 7
遍历:4-1=3,把下标为3的元素前填负号->-7
3-1=2,把下标为2的元素前填负号->-2
遍历一遍后,数组变为
-4 -3 -2 -7 8 2 -3 -1
所以4和5这对应数字没有出现过,就是5和6没有出现过
题解:
class Solution {
public:
vector<int> findDisappearedNumbers(vector<int>& nums) {
int n=nums.size();
for(int num:nums){
int x=(num-1)%n;//对n取模还原它本来的值
nums[x]+=n;//对这个元素加n
}
vector<int> ans;
for(int i=0;i<n;i++){
if(nums[i]<=n){
ans.push_back(i+1);
}
}
return ans;
}
};
2【LeetCode48】:48. Rotate Image (Medium)
题目分析:要进行原地计算。1.寻找规律 2.按顺序进行旋转操作,避免覆盖原始值。
可以将旋转过程简化为两个翻转操作:
先按照主对角线进行翻转,再左右翻转
题解:
class Solution {
public:
void rotate(vector<vector<int>>& matrix) {
int n = matrix.size();
for(int i = 0; i<n;i++){
for(int j=0;j<i;j++){//对交线翻转
swap(matrix[i][j],matrix[j][i]);
}
}
for(int i = 0; i<n;i++){
for(int j=0;j<n/2;j++){//左右翻转
swap(matrix[i][j],matrix[i][n-1-j]);
}
}
}
};
3 【LeetCode240】:240. Search a 2D Matrix II (Medium)
题目分析:在矩阵中不是边界的点有四个方向,所以我们要从某个边界开始,将四个方向转换为两个方向。这道题从右上或者左下都可以。
题解:
class Solution {
public:
bool searchMatrix(vector<vector<int>>& matrix, int target) {
int m=matrix.size();//行
int n=matrix[0].size();//列
if(m==0) return false;
// int i=0,j=n-1;//从右上开始搜索
// while(i<m&&j>=0){
// if(matrix[i][j]==target){
// return true;
// }else if(matrix[i][j]>target){
// --j;
// }else{
// ++i;
// }
// }
int i=m-1,j=0;//从左下开始搜索
while(i>=0&&j<n){
if(matrix[i][j]==target){
return true;
}else if(matrix[i][j]>target){
--i;
}else{
++j;
}
}
return false;
}
};
4 【LeetCode769】:769. Max Chunks To Make Sorted (Medium)
题目分析:因为数组元素的特性,它的元素大小范围是0-n-1(并且不重复),刚好与数组下标对应。
从左往右遍历,同时记录当前的最大值,每当 当前最大值 等于数组位置时,我们可以多一次分割。
为什么可以通过这个算法解决问题呢?
1.如果当前最大值大于数组位置,则说明右边一定有小于数组位置的数字,需要把它也加入待排序的子数组;
2.又因为数组只包含不重复的0 到n,所以当前最大值一定不会小于数组位置。
3.所以每当当前最大值等于数组位置时,说明 当前最大值 之前的值都已经出现过了,可以进行一次划分,对后续划分没有影响。我们可以成功完成一次分割。
题解:
class Solution {
public:
int maxChunksToSorted(vector<int>& arr) {
int ans=0;
int m=0;
for(int i=0;i<arr.size();++i){
m=max(m,arr[i]);
if(m==i) ++ans;
}
return ans;
}
};
LeetCode数组刷题——448、48、240、769的更多相关文章
- [LeetCode] 系统刷题5_Dynamic Programming
Dynamic Programming 实际上是[LeetCode] 系统刷题4_Binary Tree & Divide and Conquer的基础上,加上记忆化的过程.就是说,如果这个题 ...
- LeetCode的刷题利器(伪装到老板都无法diss你没有工作)
在工程效率大行其道的今天,如果不会写点代码以后也不容易在测试圈混下去.今天给大家推荐一个LeetCode的刷题利器,可以伪装到连你老板在这里走过去都无法确认你是在干活呢,还是在干活呢. LeetCod ...
- leetcode top-100-liked-questions刷题总结
一.起因 宅在家中,不知该做点什么.没有很好的想法,自己一直想提升技能,语言基础自不必言,数据结构还算熟悉,算法能力一般.于是乎,就去刷一通题. 刷题平台有很多,我选择了在leetcode进行刷题.回 ...
- LeetCode 高效刷题路径
LeetCode 高效刷题路径 Hot 100 https://leetcode.com/problemset/hot-100/ https://leetcode-cn.com/problemset/ ...
- leetcode 算法刷题(一)
今天开始刷Leetcode上面的算法题.我会更新我刷题过程中提交的代码(成功和不成功的都有)和比较好的解法 第二题 Add Two Numbers 题目的意思:输入两个链表,这两个链表都是倒序的数字, ...
- leetcode每日刷题计划-简单篇day5
刷题成习惯以后感觉挺好的 Num 27 移除元素 Remove Element 跟那个排序去掉相同的一样,len标记然后新的不重复的直接放到len class Solution { public: i ...
- leetcode每日刷题计划-简单篇day3
收到swe提前批面试hhh算是ep挂了的后续 努力刷题呀争取今年冲进去! Num 21 合并两个有序链表 Merge Two Sorted Lists 注意新开的链表用来输出结果的是ListNode ...
- leetcode每日刷题计划-简单篇day1
orzorz开始刷题 争取坚持每周平均下来简单题一天能做两道题吧 非常简单的题奇奇怪怪的错误orz越不做越菜 Num 7 整数反转 Reverse Integer 刚开始多给了一个变量来回折腾占地方, ...
- LeetCode随缘刷题之Java经典面试题将一个字符串数组进行分组输出,每组中的字符串都由相同的字符组成
今天给大家分享一个Java经典的面试题,题目是这样的: 本题是LeetCode题库中的49题. 将一个字符串数组进行分组输出,每组中的字符串都由相同的字符组成 举个例子:输入["eat&qu ...
随机推荐
- 一个Spring的应用看起来象什么?
一个定义了一些功能的接口. 这实现包括属性,它的Setter , getter 方法和函数等. Spring AOP. Spring 的XML 配置文件. 使用以上功能的客户端程序.
- 什么是bean装配?
装配,或bean 装配是指在Spring 容器中把bean组装到一起,前提是容器需要知道bean的依赖关系,如何通过依赖注入来把它们装配到一起.
- Spring框架的事务管理有哪些优点?
它为不同的事务API 如 JTA,JDBC,Hibernate,JPA 和JDO,提供一个不变的编程模式. 它为编程式事务管理提供了一套简单的API而不是一些复杂的事务API如 它支持声明式事务管理 ...
- mysql问题排查与性能优化
MySQL 问题排查都有哪些手段? 使用 show processlist 命令查看当前所有连接信息. 使用 explain 命令查询 SQL 语句执行计划. 开启慢查询日志,查看慢查询的 SQL. ...
- 名词解析-RPC
什么是RPC RPC 的全称是 Remote Procedure Call 是一种进程间通信方式.它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不用程序员显式编码这个远程 ...
- Tomcat警告之“资源添加到Web应用程序[]的缓存中,因为在清除过期缓存条目后可用空间仍不足 - 请考虑增加缓存的最大空间”
原因 缓存不够,可以将其缓存调大 解决办法: 在 /conf/context.xml 的 前添加以下内容: <Resources cachingAllowed="true" ...
- Rust 中的数据布局--可选的数据布局
Rust 允许你指定不同于默认的数据布局策略,并为你提供了不安全代码指南. repr(C) 这是最重要的"repr".它的意图相当简单:做 C 所做的事.字段的顺序.大小和对齐方式 ...
- scrapy 如何链接有密码的redis scrapy-redis 设置redis 密码 scrapy-redis如何为redis配置密码
# 使用scrapy_redis的调度器SCHEDULER = "scrapy_redis.scheduler.Scheduler"# 使用scrapy_redis的去重机制DUP ...
- html5网页录音和语音识别
背景 在输入方式上,人们总是在追寻一种更高效,门槛更低的方式,来降低用户使用产品的学习成本.语音输入也是一种尝试较多的方式,有些直接使用语音(如微信语音聊天),有些需要将语音转化为文字(语音识别).接 ...
- 将word文件转为excel文件
有些word文件里的数据是有顺序或者规律,想转成表格的形式,下面就以我要转的word为例. 我的word文件是这样的 1.word转txt(文本文件) 文件--->另存为--->路径--- ...