题解 | #二维数组的线性搜索#

# https://www.nowcoder.com/issue/tutorial?zhuanlanId=J0elbM&uuid=0524b9ad9135412ab3c8c4b9809f537f
class Solution:
    def Find(self, target: int, array: list[list[int]]) -> bool:
        if not array or not array[0]: return False
        r = len(array)
        c = len(array[0])
        i = r - 1
        j = 0 # 从左下角开始搜索
        while i >= 0 and j < c: # 边界判断
            if target == array[i][j]:
                return True
            elif target > array[i][j]: # 小了往右
                j += 1
            elif target < array[i][j]: # 大了往上
                i -= 1
        return False

if __name__ == '__main__':
    solution = Solution()
    # Example 1 -> True
    target = 7
    array = [[1,2,8,9],[2,4,9,12],[4,7,10,13],[6,8,11,15]]
    # Example 2 -> False
    target = 3
    result = solution.Find(target, array)
    print(result)

#刷题#
全部评论

相关推荐

佛系的本杰明反对画饼:个人看法,实习经历那段是败笔,可以删掉,它和你目标岗位没什么关系,没有用到什么专业技能,甚至会降低你项目经历内容的可信度。个人技能那里可以再多写一点,去boss直聘上看别人写的岗位要求,可以把你会的整合一下,比如熟悉常规的开关电源拓扑结构(BUCK、正激、反激、LLC等),熟悉常用的通信总线协议和通信接口,如UART,IIC,SPI等。简历首先是HR看的,HR大多不懂技术,会从简历里去找关键字,你没有那些关键字他可能就把你筛掉了,所以个人技能尽量针对着岗位描述写一下。还有电赛获佳绩,获奖了就写什么奖,没获奖就把获佳绩删了吧,要不会让人感觉夸大。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务