二维数组中的查找
来源:互联网 发布:中央金融企业 知乎 编辑:程序博客网 时间:2024/06/17 08:26
题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
方法:首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列(向左移);如果该数字小于要查找的数字,剔除这个数字所在的行(向下移)。如下所示:
bool Find(int* matrix, int rows, int columns, int number){ bool found = false; if (matrix != NULL && rows > 0 && columns > 0){ int row = 0; int column = columns - 1; while (row < rows && column >= 0){ if (matrix[row * columns + column] == number){ found = true; break; } else if (matrix[row * columns + column] > number){ -- column; } else { ++ row; } } } return found;}
测试用例:
- 二维数组中包含查找的数字(查找的数字是数组中的最大值和最小值,查找的数字介于数组中的最大值和最小值之间)。
- 二维数组中没有查找的数字(查找的数字大于数组中的最大值,查找的数字小于数组中的最小值,查找的数字在数组的最大值和最小值之间但数组中没有这个数字)。
- 特殊输入测试(输入空指针)。
0 0
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 二维数组中的查找
- 解决Win10 10532 不能安装Hyper-v
- 数组中出现次数超过一半的数字(剑指offer)
- 【Android开源项目解析】仿支付宝付款成功及"天女散花"效果实现——看PathMeasure大展身手
- mac通过tree源码编译安装tree
- Android 轻松实现后台搭建+APP版本更新
- 二维数组中的查找
- Git Gitosis
- App项目架构解决方案
- Fedora21安装Chromium浏览器
- CDN市场格局变动 即将迎来更激烈竞争
- 15_09_15 ( StackOverflowError ) 堆栈溢出异常
- Linux下USB设备的原理、配置、常见问题
- 【Kafka二】Kafka工作原理详解
- Android基础入门教程——7.5.6 WebView处理网页返回的错误码信息