• 剑指offer——02二维数组中的查找


    题目描述

    在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
     
    注意:
     数组不一定是这样的:
      1  2  3  
      4  5  6
      7  8  9
      而是这样的:
      1  2  8  9
      2  4  9  12
      4  7  10  13
      6  8  11  15
     
    一下给出两种方法:
    笨方法:
      从数组左上角开始查找,若target比自己大且比右边的数小,或者比最右边列的数大,则应向下查找,
      但到达下一行,可能比该数大,则应向改行的右边找,或比该数小,则向左找,这样导致代码判断繁琐
     
    优化:
      不要只会从左上角的数开始查找,观察数组之后,我们发现,每个数的右下方的数一定比自己大
      那么就从右上角开始查找,target比自己小时,则向右查找,否则向下查找,这样么每次移动只考虑向左或向右,逻辑简单明了
     
     1 class Solution {
     2 public:
     3     bool Find(int target, vector<vector<int>> array) {
     4         int px = array.size(), py = array[0].size();
     5         if (px==0 || py == 0 ||target<array[0][0] || target>array[px - 1][py - 1])return false;
     6         for (int x = 0, y = 0; y < py && x < px &&y >= 0 && x>=0;)
     7         {
     8             if (target == array[x][y])return true;
     9             else if ((y == py-1 && target > array[x][y])||(y < py - 1 && target < array[x][y + 1] && target > array[x][y]))
    10                 ++x;
    11             else if (target < array[x][y])
    12                 --y;
    13             else
    14                 y++;
    15         }
    16         return false;
    17     }
    18 };
     1 class Solution {
     2 public:
     3     bool Find(int target, vector<vector<int>> array) {
     4         int px = array.size(), py = array[0].size();
     5         if (target<array[0][0] || target>array[px - 1][py - 1])return false;
     6         int x = 0, y = py - 1;
     7         while (x < px && y >= 0)
     8         {
     9             if (target == array[x][y])return true;
    10             else if (target > array[x][y]) ++x;
    11             else if (target < array[x][y]) --y;
    12         }
    13         return false;
    14     }
    15 };
  • 相关阅读:
    【Selenium WebDriver】浏览器操作篇:打开浏览器、打开URL、关闭浏览器、获取页面的URL, Title, Source
    【读书笔记----云计算】云计算前世今生(基本概念)
    【Servlet入门】HelloServlet 小例子
    【Web前端知识从零开始】-- 浏览器F12、DOM 基础、页面元素定位
    生活常识
    工具的使用技巧
    业务知识
    工作方式
    Oracle SQL
    出差-闽西
  • 原文地址:https://www.cnblogs.com/zzw1024/p/11649975.html
Copyright © 2020-2023  润新知