首页 > 编程语言 > 详细

有序二维数组中的查找

时间:2017-08-22 01:13:18      阅读:272      评论:0      收藏:0      [点我收藏+]

  

一个二维数组,每一行按照从左到右递增,每一列按照从上到下递增,查找数组中是否存在某个数。如数组:

1  2  8    9

2  4  9   12

4  7  10  13

6  8  11  15

思路:

    这道题有其特殊性,从右上角或者左下角开始查找的方向是确定的。这句话是说比如是查找7,我们从右上角开始,9大于7,则减少列下标,查找13的话就增加行下表,查找的方向是确定的,这样就容易实现了。

 

  1. public class Item03 {  
  2.     public static void main(String args[]) {  
  3.         // 测试用的例子  
  4.         int A[][] = { { 1, 2, 8, 9 }, { 2, 4, 9, 12 }, { 4, 7, 10, 13 },  
  5.                 { 6, 8, 11, 15 } };  
  6.         System.out.println(find(A, 7));  
  7.     }  
  8.       
  9.     /** 
  10.      * 二维数组的查找 
  11.      * @param array 已知的数组 
  12.      * @param number 待查找的数 
  13.      * @return 
  14.      */  
  15.     public static boolean find(int array[][], int number) {  
  16.         boolean flag = false;  
  17.         int rows = array.length;// 行数  
  18.         int columns = array[0].length;// 列数  
  19.         int row = 0;  
  20.         int column = columns - 1;  
  21.         while (row < rows && column >= 0) {  
  22.             // 比较二维数组中的元素与number的关系  
  23.             if (array[row][column] == number) {  
  24.                 flag = true;  
  25.                 break;// 跳出循环  
  26.             } else if (array[row][column] > number) {  
  27.                 // 列变小  
  28.                 column--;  
  29.             } else {  
  30.                 // 行变大  
  31.                 row++;  
  32.             }  
  33.         }  
  34.         return flag;  
  35.     }  
  36. }  

有序二维数组中的查找

原文:http://www.cnblogs.com/joshsung/p/7407359.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!