《剑指offer》编程题java实现(一):二维数组的查找

package com.nowcoder;
/**
 * 
 * @author sk
 * 描述:用暴力逐行扫描也是可以的,但是比较麻烦,体现不出算法的优美
 * 正确的做法是从右上角(左下角)开始判断,如果目标值大于该数组值,则可以舍弃行(行是从左到右递增的),如果小于该数组值,
 * 则舍弃列,如果相等则停止,否则继续遍历,直至达到边界条件结束
 */
public class Demo1 {

    public static void main(String[] args) {
        int [] [] arr=new int [][]{
            {1,2,3},{2,3,5},{4,6,7}
        };
        Demo1 d=new Demo1();
        boolean bl_find=d.Find(9, arr);
        System.out.println(bl_find);
    }
    public boolean Find(int target,int [][] array) {
        int rows=array.length;
        int cols=array[0].length-1;
        //从右上角开始遍历
        if (rows>=0&&cols>=0) {
            int row=0;
            while(row=0) {
                if (array[row][cols]==target) {
                    return true;
                }else if (array[row][cols]else {
                    cols--;
                }
            }
        }
        return false;
    }
}

你可能感兴趣的:(剑指offer算法题,算法,面试,java)