1.【LeetCode448】:448. 找到所有数组中消失的数字

题目分析: 1-n之间有重复的,有没出现的,有出现一次。使用hashmap,空间复杂度为O(n)

方法一:哈希表,但是空间复杂度超过了O(n)

思想:

  1. 可以用hashmap存储数据,建立映射。
  2. 从1-n去遍历,看hashmap中有没有出现元素。
  3. 有出现,下一个继续遍历,没有传入数组。

方法二: 使用数组本身,这样空间就不会多用

思想:

  1. 已知元素的范围是1-n,数组下标的范围是0-n-1。从头开始遍历,比如说4,把它转换为对应的下标就是3,把3下标对应的元素变为负数(或者加n),这样就相当于 标记 与下标3对应的数。
  2. 如果某个数我们已经处理过了,这时候就要还原,然后再比较。
  3. 最后再遍历一次,找出没出现过的下标。

示例:

  1. |
  2. 4 3 2 7 8 2 3 1
  3. 0 1 2 3 4 5 6 7
  4. 遍历:4-1=3,把下标为3的元素前填负号->-7
  5. 3-1=2,把下标为2的元素前填负号->-2
  6. 遍历一遍后,数组变为
  7. -4 -3 -2 -7 8 2 -3 -1
  8. 所以45这对应数字没有出现过,就是56没有出现过

题解:

  1. class Solution {
  2. public:
  3. vector<int> findDisappearedNumbers(vector<int>& nums) {
  4. int n=nums.size();
  5. for(int num:nums){
  6. int x=(num-1)%n;//对n取模还原它本来的值
  7. nums[x]+=n;//对这个元素加n
  8. }
  9. vector<int> ans;
  10. for(int i=0;i<n;i++){
  11. if(nums[i]<=n){
  12. ans.push_back(i+1);
  13. }
  14. }
  15. return ans;
  16. }
  17. };

2【LeetCode48】48. Rotate Image (Medium)

题目分析:要进行原地计算。1.寻找规律 2.按顺序进行旋转操作,避免覆盖原始值。

可以将旋转过程简化为两个翻转操作:

先按照主对角线进行翻转,再左右翻转

题解:

  1. class Solution {
  2. public:
  3. void rotate(vector<vector<int>>& matrix) {
  4. int n = matrix.size();
  5. for(int i = 0; i<n;i++){
  6. for(int j=0;j<i;j++){//对交线翻转
  7. swap(matrix[i][j],matrix[j][i]);
  8. }
  9. }
  10. for(int i = 0; i<n;i++){
  11. for(int j=0;j<n/2;j++){//左右翻转
  12. swap(matrix[i][j],matrix[i][n-1-j]);
  13. }
  14. }
  15. }
  16. };

3 【LeetCode240】240. Search a 2D Matrix II (Medium)

题目分析:在矩阵中不是边界的点有四个方向,所以我们要从某个边界开始,将四个方向转换为两个方向。这道题从右上或者左下都可以。

题解:

  1. class Solution {
  2. public:
  3. bool searchMatrix(vector<vector<int>>& matrix, int target) {
  4. int m=matrix.size();//行
  5. int n=matrix[0].size();//列
  6. if(m==0) return false;
  7. // int i=0,j=n-1;//从右上开始搜索
  8. // while(i<m&&j>=0){
  9. // if(matrix[i][j]==target){
  10. // return true;
  11. // }else if(matrix[i][j]>target){
  12. // --j;
  13. // }else{
  14. // ++i;
  15. // }
  16. // }
  17. int i=m-1,j=0;//从左下开始搜索
  18. while(i>=0&&j<n){
  19. if(matrix[i][j]==target){
  20. return true;
  21. }else if(matrix[i][j]>target){
  22. --i;
  23. }else{
  24. ++j;
  25. }
  26. }
  27. return false;
  28. }
  29. };

4 【LeetCode769】:769. Max Chunks To Make Sorted (Medium)

题目分析:因为数组元素的特性,它的元素大小范围是0-n-1(并且不重复),刚好与数组下标对应。

从左往右遍历,同时记录当前的最大值,每当 当前最大值 等于数组位置时,我们可以多一次分割。

为什么可以通过这个算法解决问题呢?

1.如果当前最大值大于数组位置,则说明右边一定有小于数组位置的数字,需要把它也加入待排序的子数组;

2.又因为数组只包含不重复的0 到n,所以当前最大值一定不会小于数组位置。

3.所以每当当前最大值等于数组位置时,说明 当前最大值 之前的值都已经出现过了,可以进行一次划分,对后续划分没有影响。我们可以成功完成一次分割。

题解:

  1. class Solution {
  2. public:
  3. int maxChunksToSorted(vector<int>& arr) {
  4. int ans=0;
  5. int m=0;
  6. for(int i=0;i<arr.size();++i){
  7. m=max(m,arr[i]);
  8. if(m==i) ++ans;
  9. }
  10. return ans;
  11. }
  12. };

LeetCode数组刷题——448、48、240、769的更多相关文章

  1. [LeetCode] 系统刷题5_Dynamic Programming

    Dynamic Programming 实际上是[LeetCode] 系统刷题4_Binary Tree & Divide and Conquer的基础上,加上记忆化的过程.就是说,如果这个题 ...

  2. LeetCode的刷题利器(伪装到老板都无法diss你没有工作)

    在工程效率大行其道的今天,如果不会写点代码以后也不容易在测试圈混下去.今天给大家推荐一个LeetCode的刷题利器,可以伪装到连你老板在这里走过去都无法确认你是在干活呢,还是在干活呢. LeetCod ...

  3. leetcode top-100-liked-questions刷题总结

    一.起因 宅在家中,不知该做点什么.没有很好的想法,自己一直想提升技能,语言基础自不必言,数据结构还算熟悉,算法能力一般.于是乎,就去刷一通题. 刷题平台有很多,我选择了在leetcode进行刷题.回 ...

  4. LeetCode 高效刷题路径

    LeetCode 高效刷题路径 Hot 100 https://leetcode.com/problemset/hot-100/ https://leetcode-cn.com/problemset/ ...

  5. leetcode 算法刷题(一)

    今天开始刷Leetcode上面的算法题.我会更新我刷题过程中提交的代码(成功和不成功的都有)和比较好的解法 第二题 Add Two Numbers 题目的意思:输入两个链表,这两个链表都是倒序的数字, ...

  6. leetcode每日刷题计划-简单篇day5

    刷题成习惯以后感觉挺好的 Num 27 移除元素 Remove Element 跟那个排序去掉相同的一样,len标记然后新的不重复的直接放到len class Solution { public: i ...

  7. leetcode每日刷题计划-简单篇day3

    收到swe提前批面试hhh算是ep挂了的后续 努力刷题呀争取今年冲进去! Num 21 合并两个有序链表 Merge Two Sorted Lists 注意新开的链表用来输出结果的是ListNode ...

  8. leetcode每日刷题计划-简单篇day1

    orzorz开始刷题 争取坚持每周平均下来简单题一天能做两道题吧 非常简单的题奇奇怪怪的错误orz越不做越菜 Num 7 整数反转 Reverse Integer 刚开始多给了一个变量来回折腾占地方, ...

  9. LeetCode随缘刷题之Java经典面试题将一个字符串数组进行分组输出,每组中的字符串都由相同的字符组成

    今天给大家分享一个Java经典的面试题,题目是这样的: 本题是LeetCode题库中的49题. 将一个字符串数组进行分组输出,每组中的字符串都由相同的字符组成 举个例子:输入["eat&qu ...

随机推荐

  1. java中的正则表达式And Pattern And Macher

    在哪里?? java.util.regex包下有两个用于正则表达式的类, 一个是Matcher类, 另一个Pattern 简单例子 public class RegexLeaning { public ...

  2. hdu 1175 连连看 DFS_字节跳动笔试原题

    转载至:https://www.cnblogs.com/LQBZ/p/4253962.html Problem Description "连连看"相信很多人都玩过.没玩过也没关系, ...

  3. Spring 应用程序有哪些不同组件?

    Spring 应用一般有以下组件:接口 - 定义功能.Bean 类 - 它包含属性,setter 和 getter 方法,函数等.Spring 面向切面编程(AOP) - 提供面向切面编程的功能.Be ...

  4. Mybatis入门程序(一)

    1.入门程序实现需求 根据用户id查询一个用户信息 根据用户名称模糊查询用户信息列表 添加用户(二) 更新用户(二) 删除用户(二) 2.引入Mybatis所需 jar 包(Maven工程) < ...

  5. 学习openstack(六)

    VIII openstack(1) 传统的数据中心面临的问题:成本.效率(要快).管理方面(物理机.云主机): 云计算:对运维需求总体量是减少了,尤其是硬件工程师,对运维的技术要求提高了: 云计算是个 ...

  6. Linux 搭建Apollo

    简介 Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限.流程治理等特性,适用于微服务配置管理场景 ...

  7. Goland环境配置——Goland上的第一个Go语言程序

    安装好goland后,开始编写一个简单程序测试环境是否可用. 新建项目:按File-new-project进入如图new project界面,在Go一栏内的Location里填写项目路径(D:\GOO ...

  8. 以太网在汽车行业中的挑战——灵活的接口及软件使ECU开发不再复杂

    以太网在汽车行业中的挑战--灵活的接口及软件使ECU开发不再复杂 以太网将会在一批新车型中作为一个车载系统网络使用.因此,下一步就是以太网和现有汽车网络技术的集成,包括:CAN.FlexRay.LIN ...

  9. ES6-11学习笔记--const

    新声明方式:const 1.不属于顶层对象 window 2.不允许重复声明 3.不存在变量提升 4.暂时性死区 5.块级作用域   以上特性跟let声明一样,特性可看 let 的学习笔记:链接跳转 ...

  10. Zookeeper中的Leader选取机制

    一.Zookeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应 ...