美文网首页
二维数组中的查找

二维数组中的查找

作者: 愤愤的有痣青年 | 来源:发表于2019-05-28 16:41 被阅读0次

题目地址: 二维数组中的查找

题目描述

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

思路

数组是个有序矩阵,其格式如下,对其中位数而言(图中红色字体),其左上方为小于该数,右下方为大于该数


image.png

因此,考虑的一种查找方式为,从中位数开始进行判断,若数比目标值小,则查找坐标向左上部移动,反之向右下部移动,具体移动的时候要考虑是否触及了边界,以左上部移动为例,如下图,假设红色为当前值所在区域,然后判断向1方块是否能移动,并且该方块未遍历过,若能则向之移动,否则向2方块移动,经过同样的判断,若不能移动则向3方块移动,若判断还是不通过,则认为数组中无匹配的数字.


# -*- coding:utf-8 -*-
class Solution:
    # array 二维列表
    def Find(self, target, array):
        
        # 图像宽高
        w, h = len(array[0]), len(array)
        # 中位数坐标
        center_y, center_x = h // 2, w // 2
        
        # 遍历
        while True:
            
            # 判断坐标是否有越界,若有则返回False
            if center_x < 0 or center_x >= w:
                return False
            if center_y < 0 or center_y >= h:
                return False
            
            # 判断该坐标是否已经搜索过,若是则退出(已经搜索过的需要将值标记为"a")
            if array[center_y][center_x] == "a":
                return False
            
            # 缓存当前坐标
            x, y = center_x, center_y
            
            if array[center_y][center_x] == target:
                # 匹配成功
                return True
            elif array[center_y][center_x] > target:
                # 当前值比目标值大,因此需要向左半部移动
                
                # 详判断能否向方块1处移动
                if center_y > 0 and center_x > 0:
                    if array[center_y - 1][center_x - 1] != "a":
                        center_x, center_y = center_x - 1, center_y - 1
                        
                        # 标记为已搜索
                        array[y][x] = "a"
                        continue

                # 详判断能否向方块2处移动
                if center_y > 0 and array[center_y - 1][center_x] != "a":
                    center_y -= 1
                    array[y][x] = "a"
                    continue

                # 详判断能否向方块3处移动
                if center_x > 0 and array[center_y][center_x - 1] != "a":
                    center_x -= 1
                    array[y][x] = "a"
                    continue
                
                # 不可移动,返回无搜索结果
                return False
            else:
                if center_y < h - 1 and center_x < w - 1:
                    if array[center_y + 1][center_x + 1] != "a":
                        center_x, center_y = center_x + 1, center_y + 1
                        array[y][x] = "a"
                        continue
                if center_y < h - 1 and array[center_y + 1][center_x] != "a":
                    center_y += 1
                    array[y][x] = "a"
                    continue

                if center_x < w - 1 and array[center_y][center_x + 1] != "a":
                    center_x += 1
                    array[y][x] = "a"
                    continue

                return False

相关文章

  • 算法题

    行列都是有序的二维数组,查找k是否存在【查找法】 二维数组中的查找(行列分别有序数组的二分查找)【递归法】 快速排...

  • 剑指Offer二维数组查找

    剑指Offer二维数组查找 二维数组查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到...

  • 剑指offer4.二维数组中的查找

    题目 题目分析 算法-二维数组中的查找 比如一个二维数组是这样: 要查找数组7在不在数组内,根据前人总结出来的规律...

  • 《剑指offer》(一)-二维数组中的查找(java)

    数组--二维数组中的查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序...

  • 刷题-数组专项

    数组 二维数组中的查找题目描述:在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每...

  • 二维数组中的查找(Javascript编程) function Find(target, array){ // w...

  • 牛客网高频算法题系列-BM18-二维数组中的查找

    牛客网高频算法题系列-BM18-二维数组中的查找 题目描述 在一个二维数组array中(每个一维数组的长度相同),...

  • 数组——二维数组中查找

    一、题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下...

  • LeetCode 每日一题 [39] 二维数组中的查找

    LeetCode 二维数组中的查找 [简单] 在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序...

  • 剑指offer(Java版)day01:二维数组中的查找|替换空

    1二维数组中的查找 【题目】在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每...

网友评论

      本文标题:二维数组中的查找

      本文链接:https://www.haomeiwen.com/subject/jebdtctx.html