牛客每日刷题之数组

发布时间:2023-02-27 09:30

✅作者简介:我是18shou,一名即将秋招的java实习生

✨个人主页:_18shou

系列专栏:牛客刷题专栏

推荐一款模拟面试、刷题神器 在线刷题面经模拟面试

目录

看题1之二维数组中的查找

思路1

代码1

复杂度1

题目2之数组中重复的数字

思路2.1

代码2.1

复杂度2.1

思路2.2

代码2.2

复杂度2.2

结语



牛客每日刷题之数组_第1张图片

看题1之二维数组中的查找

在一个二维数组array中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
[1,2,8, 9],

[2,4,9,12],

[4,7,10,13],

[6,8,11,15]]
给定target = 7,返回true。给定target = 3,返回false。
数据范围:矩阵的长宽满足0≤n, m ≤ 500,矩阵中的值满足0≤val ≤109进阶:空间复杂度O(1),时间复杂度O(n + m)

思路1

由于给定的二维数组具备每行从左到右递增以及每列从上到下递增的特点,当访问到一个元素时,可以排除数组中的部分元素。
从二维数组的右上角开始查找。如果当前元素等于目标值,则返回true。如果当前元素大于目标值,则移到左边一列。如果当前元素小于目标值,则移到下边一行。
可以证明这种方法不会错过目标值。如果当前元素大于目标值,说明当前元素的下边的所有元素都一定大于目标值,因此往下查找不可能找到目标值,往左查找可能找到目标值。如果当前元素小于目标值,说明当前元素的左边的所有元素都一定小于目标值,因此往左查找不可能找到目标值,往下查找可能找到目标值。
·若数组为空,返回false
·初始化行下标为0,列下标为二维数组的列数减1·重复下列步骤,直到行下标或列下标超出边界
。获得当前下标位置的元素num
。如果num和target相等,返回true。如果num 大于target,列下标减1。如果num小于target,行下标加1
·循环体执行完毕仍未找到元素等于target ,说明不存在这样的元素,返回false

代码1

public class Solution {
    public boolean Find(int target, int [][] array) {
        if(array == null || array.length == 0 || array[0].length == 0) {
            return false;
        }
        // 0 array[0].length-1
        int i = 0;
        int j = array[0].length - 1;
        while (i < array.length && j >= 0) {
            if(target == array[i][j]){
                return true;
            }else if(target > array[i][j]) {
                i++;
            }else {
                j--;
            }
        }
        return false;
    }
}

复杂度1

·时间复杂度:O(n + m)。访问到的下标的行最多增加n次,列最多减少m次,因此循环体最多执行n +m次。
·空间复杂度:O(1)。

牛客每日刷题之数组_第2张图片

题目2之数组中重复的数字

牛客每日刷题之数组_第3张图片

思路2.1

1.遍历数组nums , 设系例始宜力i=0 :
1.若nums[i]=i:说明此数字已在对应索引位置,无需交换,因此跳过;
2.若nums[nums[i刮]]=nums[i]:代表索引 nums[i]处和索引à处的元素值都为nums[i],即找到一组重复值,返回此值nums[i] ;
3.否则:交换索引为i和nums[i]的元素值,将此数字交换至对应索引位置。
⒉.若遍历完毕尚未返回,则返回-1。
 

代码2.1

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param numbers int整型一维数组 
     * @return int整型
     */
    public int duplicate (int[] nums) {
        int i = 0;
        while(i < nums.length) {
            if(nums[i] == i){
                i++;
                continue;
            } 
            if(nums[nums[i]] == nums[i]){
                return nums[i];
                
            }
                int tmp = nums[i];
                nums[i] = nums[tmp];
                nums[tmp] = tmp;
            
        }
        return - 1;
    }
}

复杂度2.1

复杂度分析:
时间复杂度O(N)︰遍历数组使用O(N),每轮遍历的判断和交换操作使用O(1)。

空间复杂度O(1):使用常数复杂度的额外空间。

牛客每日刷题之数组_第4张图片

思路2.2

直接遍历

由于只需要找出数组中任意一个重复的数字,因此遍历数组,遇到重复的数字即返回。为了判断一个数字是否重复遇到,使用集合存储已经遇到的数字,如果遇到的一个数字已经在集合中,则当前的数字是重复数字。
初始化集合为空集合,重复的数字repeat = -1·遍历数组中的每个元素:
将该元素加入集合中,判断是否添加成功
如果添加失败,说明该元素已经在集合中,因此该元素是重复元素,将该元素的值赋给repeat ,并结束遍历
返回repeat

代码2.2

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param numbers int整型一维数组 
     * @return int整型
     */
    public int duplicate (int[] nums) {
        Set set = new HashSet();
        int repeat = -1;
        for (int num : nums) {
            if (!set.add(num)) {
                repeat = num;
                break;
            }
        }
        return repeat;
    }
}

牛客每日刷题之数组_第5张图片

复杂度2.2

复杂度分析:
时间复杂度O(N)

空间复杂度O(N)

结语

兄弟们,一起来刷题嘎嘎的写题

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号