時念
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
    • JavaScript 基础
  • 后端笔记

    • Java
    • Spring
    • 算法
    • 高可用
    • 高并发
  • 工作问题

    • 问题记录
  • 各类工具使用
  • GitHub技巧
  • 博客搭建
  • 面试题库

    • 零碎
    • 面试常见题目汇总
  • 面试心得

    • 面试集锦
    • 杂言碎语
  • 摘抄收录

    • ☆ 励志鸡汤
    • ❀ 人间烟火
    • ☣ 万物沦丧
    • ✌ 关掉烦恼
    • ✲ 小酒馆
  • 读书笔记

    • 《小狗钱钱》
    • 《穷爸爸富爸爸》
    • 《聪明人使用方格笔记本》
  • 学习
  • 心情杂货
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub

時念

一个有梦想的后端小菜鸡(✪ω✪)
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
    • JavaScript 基础
  • 后端笔记

    • Java
    • Spring
    • 算法
    • 高可用
    • 高并发
  • 工作问题

    • 问题记录
  • 各类工具使用
  • GitHub技巧
  • 博客搭建
  • 面试题库

    • 零碎
    • 面试常见题目汇总
  • 面试心得

    • 面试集锦
    • 杂言碎语
  • 摘抄收录

    • ☆ 励志鸡汤
    • ❀ 人间烟火
    • ☣ 万物沦丧
    • ✌ 关掉烦恼
    • ✲ 小酒馆
  • 读书笔记

    • 《小狗钱钱》
    • 《穷爸爸富爸爸》
    • 《聪明人使用方格笔记本》
  • 学习
  • 心情杂货
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub
  • java

  • spring

  • 问题记录

  • 算法

    • 链表
    • 双指针
    • 二叉树
    • 回溯
    • (伪)二分
    • 堆
    • 贪心
    • 动态规划
    • 多维动态规划
    • 技巧
    • 数组
    • 子串
    • 滑动窗口
    • 哈希
    • (伪)栈
    • 数组混淆点整理
      • 最大子数组和
      • 最大子数组乘积
      • 无重复字符的最长子串 (滑动窗口)
      • 组合总和 (回溯)
      • 最长递增子序列 (动态规划)
      • 最长回文子串 (双层for 暴力破解)
      • 最长公共子序列 (二维动态规划)
      • 最长连续序列
      • 最长连续递增序列
  • 高可用

  • 后端
  • 算法
時念
2024-01-19

数组混淆点整理

不写代码 只讲思路

# 最大子数组和

  1、先定义 pre 跟 max ,max用于返回, 初始值为nums[0];
  2、for循环 迭代nums, 
  3、pre的值为  num 跟 pre+num取最大值
  4、max的值为  max 跟 pre取最大值  
  5、结束
1
2
3
4
5

# 最大子数组乘积

  1、先定义 max 用于返回 imax = 1 跟 imin = 1;
  2、遍历nums 
  3、如果 num[i] < 0,imax 跟 imin 交换值
  4、imax  = max (imax * num[i], nums[i])
  5、imin  = min (imin * num[i], nums[i])
  6、最后  imax 跟 max 取最大值赋值给max
  7、返回max
1
2
3
4
5
6
7

# 无重复字符的最长子串 (滑动窗口)

1、 set判断  
1

# 组合总和 (回溯)

# 最长递增子序列 (动态规划)


1、定义dp 填充
2、定义max用于返回
3、然后两层for  动态规划这边的第二层for一般都还是j<i 的(或者可能加其他的)
4、 if(nums[j]< nums[i]){dp[i] = Math.max(dp[i], dp[j]+1);} 记录
  5、最后对比max跟dp[i] 取最大值

1
2
3
4
5
6
7

# 最长回文子串 (双层for 暴力破解)

# 最长公共子序列 (二维动态规划)

# 最长连续序列

class Solution {
    public int longestConsecutive(int[] nums) {
        if(nums == null || nums.length == 0){
            return 0;
        }
        Arrays.sort(nums);
        Set<Integer> set = new LinkedHashSet<>();
        for(int i : nums){
            set.add(i);
        }
        int res = 1;
        int start = 1;
        int item = Integer.MIN_VALUE;
        for(Integer i : set){
            if(i- item == 1){
                start++;
            }else{
                start = 1;
            }
            item = i;
            res = Math.max(res, start);
        }

        return res;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

# 最长连续递增序列

class Solution {
    public int findLengthOfLCIS(int[] nums) {
        int count = 1;
        int res = 1;
        for(int i = 0; i< nums.length-1;i++){
            if(nums[i+1] > nums[i]){
                count ++;
            } else {
                count = 1;
            }
            if(count > res){
                res = count;
            }
        }

        return res;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
编辑
上次更新: 2024/03/26, 9:03:00
(伪)栈
index

← (伪)栈 index →

最近更新
01
database-shard-dynamic-expand
03-26
02
README
03-26
03
database-shard-global-id-generate
03-26
更多文章>
Theme by Vdoing | Copyright © 2019-2024 時念 | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式