二维数组矩阵查询,输入的第一行为两个整数代表将要输入的矩阵的行数和列数,输入的第二行代表要查找的数字。
2014-04-23 00:20
344 查看
/**
* 输入可能包含多个测试样例,对于每个测试案例,
输入的第一行为两个整数m和n(1<=m,n<=1000):代表将要输入的矩阵的行数和列数。
输入的第二行包括一个整数t(1<=t<=1000000):代表要查找的数字。
接下来的m行,每行有n个数,代表题目所给出的m行n列的矩阵(矩阵如题目描述所示,
每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。
*
*/
请输入矩阵行数m:3
请输入矩阵列数n:3
请输入需要搜索的数data:5
请输入9个数据(数据间用空格隔开):
1 2 3 4 5 6 7 8 9
Yes!!
* 输入可能包含多个测试样例,对于每个测试案例,
输入的第一行为两个整数m和n(1<=m,n<=1000):代表将要输入的矩阵的行数和列数。
输入的第二行包括一个整数t(1<=t<=1000000):代表要查找的数字。
接下来的m行,每行有n个数,代表题目所给出的m行n列的矩阵(矩阵如题目描述所示,
每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。
*
*/
package cn.itcast.demo9; import java.util.Scanner; public class dimenArrayTwo2 { public static void main(String[] args){ dimenArrayTwo2 dat = new dimenArrayTwo2(); dat.input(); } private void input() { Scanner scan = new Scanner(System.in); System.out.print("请输入矩阵行数m:"); int m = scan.nextInt(); System.out.print("请输入矩阵列数n:"); int n = scan.nextInt(); System.out.print("请输入需要搜索的数data:"); int data = scan.nextInt(); int[][] arr = new int[m] ; //判断数据合法 if(!(m>0 && m<1000 && n>0 && n<1000 && data>0 && data<1000000)){ System.out.println("please input right number"); System.exit(0); } else{ //构建矩阵 System.out.println("请输入"+m*n+"个数据(数据间用空格隔开):"); int arri; for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ arri = scan.nextInt(); arr[i][j] = arri; } } } boolean flag = findNumber(arr,data); if(flag == false){ System.out.println("No!!"); } else{ System.out.println("Yes!!"); } } private boolean findNumber(int[][] arr, int data) { boolean flag = false; //先求出m行,n列 int m = arr.length; int n = arr[0].length; int mrow,ncolumn; mrow = 0; ncolumn = n - 1; //这里的判断循环是从上面定义的值得到的 while(mrow<m && ncolumn>=0){ if(arr[mrow][ncolumn] == data){ flag = true; return flag; } else if(arr[mrow][ncolumn] >data){ ncolumn--; } else if(ncolumn<n-1 && arr[mrow][ncolumn] <data){ ncolumn++; } else{ mrow++; } } return flag; } }输出结果:
请输入矩阵行数m:3
请输入矩阵列数n:3
请输入需要搜索的数data:5
请输入9个数据(数据间用空格隔开):
1 2 3 4 5 6 7 8 9
Yes!!
相关文章推荐
- 题目“计算A+B,输入第一行为一个整数n(1≤n≤10)代表测试的组数。 下面有n组测试数据,每组1行,为2个整数,为A,B。”——代码调试有误
- 【剑指offer24】输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
- 输入任意两个整数数字,计算这两个数字间能被3整除的数的和
- 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
- 【算法】输入一个已经按升序排过的数组和数字,在数组中查找两个数字,使得它们的和正好是输入那个数字。
- 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)
- 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
- 牛牛和15朋友来玩打土豪分田地的游戏,牛牛决定让你来分田地,地主的田地可以看成是一个矩形,每个位置有一个价值。分割田地的方法是横竖各切三刀,分成26份,作为领导干部,牛牛总是会选择其中总价值最小的一份田地,作为牛牛最好的朋友,你希望牛牛取得的田地价值和尽可能大,你知道这个值最大可以是多少吗? 输入两个整数n和m(1≤n,m≤75)表示田地的大小,接下来n行,每行包括m个0-9之间的数字,表示每块
- 【c语言】二维数组中的查找,杨氏矩阵在一个二维数组中,每行都依照从左到右的递增的顺序排序,输入这种一个数组和一个数,推断数组中是否包括这个数
- 二维数组中的查找-在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
- 查找介于n1与n2(0<n1<n2<32768)之间所有满足下列条件的整数: (1)该数的十进制表示中有且仅有两个相同的数字位; (2)该数是素数。
- 微软面试14题 输入一个已经按升序排序过的数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字。
- 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一
- 从键盘输入一个整数(1~20) 则以该数字为矩阵的大小,把1,2,3…n*n 的数字按照顺时针螺旋的形式填入其中。
- 【c语言】二维数组中的查找,杨氏矩阵在一个二维数组中,每行都按照从左到右的递增的顺序排序,输入这样的一个数组和一个数,判断数组中是否包含这个数
- 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一
- 输入一个奇数n,打印出一个n*n的矩阵,每个数字是从1到n*n的整数,要使每一行,每一列的数字之和都相等
- 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
- 《剑指Offer》输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
- java 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。