牛客每日刷题之数组

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

✨个人主页:_18shou

🔥系列专栏:牛客刷题专栏

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

目录

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

思路1

代码1

复杂度1

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

思路2.1

代码2.1

复杂度2.1

思路2.2

代码2.2

复杂度2.2

📃结语



看题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·重复下列步骤ÿ

  • 24
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 34
    评论
评论 34
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值