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

一、题目

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放在nums[0],把元素2放在nums[1],这样,这个数组中没出现的最小正整数,就是最先没出出现在对应位置的那个整数。如[1,2,0],下标为2的位置应该是3,但是是0不是3,那么3就是数组中没出现的最小正整数。

把每个符合条件的元素放在对应位置上,遍历过程中需要加一条判断nums[i]!=nums[nums[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,那么就会把第一个元素matrix[0][0]设为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;
            }
        }
        
    }
}
相关推荐
计算机安禾1 小时前
【计算机网络】第11篇:链路状态路由协议——Dijkstra算法与OSPF的分区架构
计算机网络·算法·架构
珂朵莉MM1 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第二赛季优化题--遗传算法
人工智能·算法
gihigo19981 小时前
严格耦合波分析计算光栅衍射效率算法
算法
可编程芯片开发1 小时前
基于双Qlearning强化学习的温差发电系统电压动态补偿算法matlab仿真
算法·matlab·双qlearning强化学习·电压动态补偿·温差发电系统
Java成神之路-2 小时前
【LeetCode 刷题笔记】69.x 的平方根 | 二分查找经典刷题题解
算法·leetcode
灵智实验室2 小时前
PX4状态估计技术EKF2详解(一):EKF2 开篇——从分离到统一
算法·无人机·px 4
小智老师PMP2 小时前
六月PMP晚启动急救|现在开始,每天2-3小时,稳冲一次上岸(附可直接照搬计划)
算法·软件工程·求职招聘·产品经理·敏捷流程
tankeven2 小时前
动态规划专题(11):区间动态规划之三角剖分问题
c++·算法·动态规划
joshchen2152 小时前
强化学习基础(赵世钰)第一章
人工智能·深度学习·算法·机器学习·强化学习