二维数组查找--C语言

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二维数组查找--C语言相关的知识,希望对你有一定的参考价值。

方法一:线性查找

算法流程:

1.首先找到最右上角的元素,a[row][col],要找的target可以与其做比较对二维

数组进行分析可以发现每一行中最右边的元素是最大的,严格单调递增

2.target比最右边这个元素要小,那么col-- 就是列减少我们倒着遍历这一行每

个元素,直到找到最终的target

3.target比最右边这个元素还大,这一行就肯定不存在我们要找的target了,

这时候我们要在下一行去找 row++

4.target比a[row][col]小的话,我们就在 row+1 这一行去找,不然再到 row+2 行去找...

代码:

public class Solution

   public boolean Find(int [][] array,int target)

       int row=0;

       int col=array[0].length-1;

       while(row<=array.length-1&&col>=0)

           if(target==array[row][col])

               return true;

           else if(target>array[row][col])

               row++;

           else

               col--;

       

       return false;

   

方法二:遍历

把每一行看成有序递增的数组,利用二分查找,

通过遍历每一行得到答案,时间复杂度是nlogn

代码:

public class Solution

   public boolean Find(int [][] array,int target)

         for(int i=0;i<array.length;i++)

           int low=0;

           int high=array[i].length-1;

           while(low<=high)

               int mid=(low+high)/2;

               if(target>array[i][mid])

                   low=mid+1;

               else if(target<array[i][mid])

                   high=mid-1;

               else

                   return true;

           

       

       return false;

   

以上是关于二维数组查找--C语言的主要内容,如果未能解决你的问题,请参考以下文章

二维数组查找--C语言

二维数组中的查找(杨氏矩阵(C语言+Java))

剑指offer系列——二维数组中的查找

快速查找二维数组的所有峰值,c语言实现最好,python也可以,最好能实现滤波。

c语言二维数组中的查找,杨氏矩阵在一个二维数组中,每行都依照从左到右的递增的顺序排序,输入这种一个数组和一个数,推断数组中是否包括这个数

offer 二维数组查找