1. 程式人生 > >題目一:使用Java實現二維數組中的查找

題目一:使用Java實現二維數組中的查找

ray class 如果 strong www. 循環 順序 選擇 com

考點:數組 題目:二維數組中的查找 描述:在一個二維數組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數,輸入這樣的一個二維數組和一個整數,判斷數組中是否含有該整數。 方式一:選擇從左下角開始搜尋,因為選擇在左下角搜尋的話,如果目標值大於搜索值,那麽就向右繼續搜索,如果目標值小於搜索值,那麽就向上繼續搜索。在左上角就無法形成這樣的判斷。時間復雜度為:0(lgn)
package cn.imooc.java2;
public class Solution {
    public boolean Find(int [][] array,int target) {
        //定義多維數組的行數
        int m = array.length - 1;
        //定義多維數組的列數
        int i = 0;
        while(m >= 0 && i < array[0].length){
            if(array[m][i] > target)
                m--;
            else if(array[m][i] < target)
                i++;
            else
                return true;
        }        
        return false;
    }
    public static void main(String[] args) {
          Solution s = new Solution();
          int[][] b={{1,2,3},{4,5,6}};
          //測試一個兩行三列的數組,目標值為0      
          System.out.println(s.Find(b, 0));
     }
}

  

方式二:

package cn.imooc.java2;
public class Test02 {
     public boolean Find(int [][] array,int target) {
          //循環輸出行
        for(int[] i : array){
          //循環輸出列
            for(int j : i){
                if(j==target){
                   return true;
                }
            }
        }
        return false;
    }
     public static void main(String[] args) {
          Solution s = new Solution();
          int[][] b={{1,2,3},{4,5,6}};      
          System.out.println(s.Find(b, 4));
     }
}

優點:方法簡單,代碼少 確定:時間復雜度為O(n^2),偏高。影響程序的性能。

方式一和方式二涉及到的知識點有:二維數組、算法復雜度、二分查找算法、foreach循環以及二維數組當做形參傳入。

題目一:使用Java實現二維數組中的查找