算法题(普通数组、矩阵)

一、题目

1、除自身以外数组的乘积(LC 238)

2、缺失的第一个正数(LC 41)

3、矩阵置零(LC 73)

二、题解

1、除自身以外数组的乘积(LC 238)

(1)分析

如果使用除法,可以先计算数组中元素为零的个数,再计算除了零以外其他元素的总乘积。当零的个数大于等于二,返回的数组answer中元素都为零;当零的个数等于一,answer中只有对应下标的元素等于乘积,answer中其余元素都都为零;当没有零,answer中每个元素都等于总乘积除以对应下标的nums元素。

不使用除法,可以用动态规划的方法解决。先计算每个元素左侧所有元素的乘积,再计算每个元素右侧所有元素的乘积,每个元素对应的两个乘积相乘,结果就是answer对应位置的元素。

(2)解答

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int[] ans = new int [nums.length];
        ans[0] = 1;
        int temp = 1;

        for(int i = 1; i<nums.length; i++){
            ans[i] = ans[i-1]*nums[i-1];
        }
        for(int i = nums.length-2; i>=0; i--){
            temp = nums[i+1] * temp;
            ans[i] = ans[i] * temp;

        }
        return ans;
    }
}

2、缺失的第一个正数(LC 41)

(1)分析

本题使用原地哈希的方法解决。因为所求的是数组中没出现的最小正整数,可以将元素n放到下标为n-1的位置,如数组1,2,0,把元素1放在nums0,把元素2放在nums1,这样,这个数组中没出现的最小正整数,就是最先没出出现在对应位置的那个整数。如1,2,0,下标为2的位置应该是3,但是是0不是3,那么3就是数组中没出现的最小正整数。

把每个符合条件的元素放在对应位置上,遍历过程中需要加一条判断numsi!=numsnums\[i - 1],防止因为重复元素导致出现死循环。

(2)解答

java 复制代码
class Solution {
    public int firstMissingPositive(int[] nums) {
        int n = nums.length;
        for(int i = 0; i<n; i++){
            while(nums[i]>=1 && nums[i]<=n && nums[i]!=nums[nums[i] - 1]){
                swap(nums, nums[i] - 1, i);

            }
        }
        for(int i=1; i<=n; i++){
            if(i != nums[i-1]){
                return i;
            }
        }
        return n+1;
        
    }
    public void swap(int[] nums ,int index1, int index2){
        int temp = nums[index1];
        nums[index1] = nums[index2];
        nums[index2] = temp;

    }
}

3、矩阵置零(LC 73)

(1)分析

遍历数组中每个元素,当某个元素为0,将该元素所在行和所在列的第一个元素设为0,然后根据第一行的元素和第一列的元素来决定是否设为0。但是有弊端,如果第一行都为1,第一列有0,那么就会把第一个元素matrix00设为0,会导致置零时将第一列都置为零。所以第一行第一列的元素要单独考虑,用两个变量来表示第一行、第一列是否含有零。先考虑其他行和列,最后根据这两个变量决定第一行和第一列是否需要指令。时间复杂度为O(mn),空间复杂度为O(1)。

(2)解答

java 复制代码
class Solution {
    public void setZeroes(int[][] matrix) {
        int m = matrix.length;
        int n = matrix[0].length;
        boolean firstRowHasZero = false;
        for(int x : matrix[0]){
            if(x == 0){
            firstRowHasZero = true;
            break;

            }
        }
        boolean firstColHasZero = false;
        for(int i = 0; i<m; i++){
            if(matrix[i][0] == 0){
            firstColHasZero = true;
            break;
            }
        }
        for(int i = 1; i < m; i++){
            for(int j = 1; j < n; j++){
                if(matrix[i][j] == 0){
                    matrix[i][0] = 0;
                    matrix[0][j] = 0;
                }
            }
        }

        for(int i = 1; i < m; i++){
            for(int j = 1; j < n; j++){
                if(matrix[i][0] == 0 || matrix[0][j] == 0){
                    matrix[i][j] = 0;
                }
            }
        }

        if(firstRowHasZero){
            for(int i = 0; i < n; i++){
                matrix[0][i] = 0;
            }
        }
        if(firstColHasZero){
            for(int i = 0; i < m; i++){
                matrix[i][0] = 0;
            }
        }
        
    }
}
相关推荐
JieE21221 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架