剑指offer学习笔记【二维数组的查找】

来源:互联网 发布:nokia5310软件下载 编辑:程序博客网 时间:2024/04/28 08:00
  在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 
输入描述:
array: 待查找的二维数组target:查找的数字
代码:
public class Solution {    public boolean Find(int [][] array,int target) {        boolean found = false;        if(found == false){   for(int i = 0; i < array[0].length; i ++){             for(int j = 0; j < array.length; j ++){                   if(target == array[i][j])                       found = true;               }            }        }        return found;    }}
学习笔记:
    1、数组列的长度 array[0].length;
    2、二维数组展开成一维数组:
int [] tempArray = new int[array.length][array[0].length];    int index = 0;    for (int i = 0; i < array[0].length; i ++){        for(int j = 0; j < array.length; j ++){            tempArray[index ++] = array[i][j];        }    }
0 0