LeetCode Hot 100 第7天

1. 189 轮转数组(规律)

链接题目链接
题解

题解 时间复杂度O(n)

  1. k = n * len + x (len等于数组长度),n * len 可以忽略掉(将数组向右轮转n * len次,数组不会发生任何变化),所以真正需要处理的轮转次数 x = k % len
  2. 数组像右轮转x次 = 尾部x个元素移动到数组头部 + 其余元素向右移动
  3. 尾部x个元素移动到数组头部:先将数组反转,再将0, x - 1下标元素反转
  4. 其余元素向右移动:先将数组反转,再将x, len - 1下标元素反转

代码

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        int len = nums.length;
        k = k % len;
        swapRange(nums, 0, len - 1);
        swapRange(nums, 0, k - 1);
        swapRange(nums, k, len - 1);
    }

    private void swapRange(int[] nums, int l, int r) {
        while(l < r) {
            int temp = nums[l];
            nums[l] = nums[r];
            nums[r] = temp;
            l ++;
            r --;
        }
    }
}

2. 238 除自身以外数组的乘积(公式 + 规律)

链接题目链接
题解

题解 时间复杂度O(n)

  1. answer[i] = nums 中除 nums[i] 之外其余各元素的乘积 = 所有乘积 / nums[i](nums[i]=0的情况需要特殊讨论)
  2. 遍历数组维护所有元素的乘积
  3. 注意:当numsi=0 && 0的个数>1时,answer数组都是0
  4. 注意:当numsi=0 && 0的个数=1时,answeri = 非0数的乘积,answerj = 0 (j != i)
  5. 其他情况参考1

代码

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        // 0的个数 个数 > 1 直接返回0数组 个数 == 0 乘积不算0 记录0下标 个数 == 0 直接算0下标
        int len = nums.length;
        int zeroCount = 0;
        int zeroIndex = -1;
        int allMultiplicationResult= 1;
        for (int i = 0; i < len; ++ i) {
            if (nums[i] == 0) {
                zeroCount ++;
                zeroIndex = i;
            } else {
                allMultiplicationResult *= nums[i];
            }
        }
        int[] ans = new int[len];
        if (zeroCount > 1) {
            return ans;
        } 
        if (zeroCount == 1) {
            ans[zeroIndex] = allMultiplicationResult;
            return ans;
        }

        for (int i = 0; i < len; ++ i) {
            ans[i] = allMultiplicationResult / nums[i];
        }
        
        return ans;
    }
}

3. 41 缺失的第一个正数(规律 + hash)

链接题目链接
题解

题解 时间复杂度O(n)

  1. 当nums数组长度为n时,缺失的最小整数的最大值是n+1,例如最极端的情况1, 2, 3 那么确缺失的最小整数 = 4
  2. 从1遍历至n,hash存储出现过的值,如果i值 不存在hash中,那么就是缺失的最小整数
  3. 题目要求时间复杂度为O(1)常数级别,那么只能把hash存储在nums数组中体现
  4. numsi <= 0的情况元素无效,那么等值替换为n + 1(即最大可能取到的值)
  5. 因为答案存在1, n + 1,那么我们把i值映射在i-1下标元素上,用负数表示已存在(负数不会影响nums的绝对值)
  6. 遍历元素,做完hash映射时,再遍历一遍数组,如果numsi > 0(没被hash标记),那么缺失的最小整数就是i +1
  7. 遍历元素,数组都被标记时(numsi <= 0),那么缺失的最小整数就是n + 1

代码

java 复制代码
class Solution {
    public int firstMissingPositive(int[] nums) {
        int len = nums.length;
        for (int i = 0; i < len; ++ i) {
            if (nums[i] <= 0) {
                nums[i] = len + 1;
            }
        }
        for (int i = 0; i < len; ++ i) {
            int absNum = Math.abs(nums[i]);
            if (absNum <= len) {
                nums[absNum - 1] = -1 * Math.abs(nums[absNum - 1]);
            }
        }
        for (int i = 0; i < len; ++ i) {
            if (nums[i] > 0) {
                return i + 1;
            }
        }
        return len + 1;
    }
}

如果对你有帮助,辛苦点个赞,谢谢啦,朋友!!!

相关推荐
JieE2123 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术8 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦9 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户4978630507312 小时前
(一)小红的数组操作
算法·编程语言
怕浪猫15 小时前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕17 小时前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆1 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人