《剑指offer》第四题(二维数组中的查找)
// 二维数组中的查找
// 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按
// 照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个
// 整数,判断数组中是否含有该整数。 #include <iostream>
using namespace std; bool serach_in(int* matrix, int rows, int cols, int number)
{
bool flag = false; if ((matrix != NULL) && (rows > ) && (cols > ))//判断不能忘
{
int row = , col = cols - ;
while ((row < rows) && (col >= ))
{
if (matrix[row*cols + col] == number)
{
flag = true;
break;
}
else if (matrix[row*cols + col] > number)//用实例分析过程,思想比程序更重要
col--;
else
row++;
}
} return flag;
} void test1()//要查找的数在数组中
{
cout << "Test1:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test2()//要查找的数不在数组中
{
cout << "Test2:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test3()//要查找的数是数组中最小的数字
{
cout << "Test3:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test4()//要查找的数是数组中最大的数字
{
cout << "Test4:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test5()//要查找的数比数组中最小的数字还小
{
cout << "Test5:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test6()//要查找的数比数组中最大的数字还大
{
cout << "Test6:\n";
int matrix[][] = { {, , , }, {, , , }, {, , , }, {, , , } };
bool result;
result = serach_in(matrix[], , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} void test7()//鲁棒性测试,输入空指针
{
cout << "Test6:\n";
bool result;
result = serach_in(NULL, , , );
if (result)
cout << "Yes!\n";
else
cout << "No!\n";
} int main()
{
test1();
test2();
test3();
test4();
test5();
test6();
test7();//重点,鲁棒性测试 system("pause");
}
《剑指offer》第四题(二维数组中的查找)的更多相关文章
- 剑指Offer - 九度1384 - 二维数组中的查找
剑指Offer - 九度1384 - 二维数组中的查找2013-11-23 23:23 题目描述: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个 ...
- 《剑指Offer》面试题-二维数组中的查找
题目1384:二维数组中的查找 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:7318 解决:1418 题目描述: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到 ...
- 剑指offer【01】- 二维数组中的查找(Java)
在经历了春招各大公司的笔试题和面试官的血虐之后,决定要刷一些算法题了,不然连面试机会都没有. 而应对笔试和面试,比较出名的就是剑指offer的题目和LeetCode的题目了.剑指offer应对面试中的 ...
- 剑指offer第二版-4.二维数组中的查找
面试题4:二维数组中的查找 题目要求: 一个二维数组中,每一行从左到右递增,每一列从上到下递增.输入一个整数,判断数组中是否含有该整数 /** * @since 2019年2月13日 下午5:08:5 ...
- 剑指offer面试题3二维数组中的查找
题目: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 需要与面试官确认的是,这 ...
- 剑指offer面试题4: 二维数组中的查找
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
- 【剑指Offer】1、二维数组中的查找
题目描述: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否 ...
- 剑指offer(3)——二维数组中的查找
题目: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 思路: 首先选取数组中右上 ...
- 剑指offer学习读书笔记--二维数组中的查找
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都是按照从上到下递增的顺序排序.请设计一个函数,输入这样的一个二维数组和一个整数,判断数组是否含有这个整数. 1 2 8 9 2 4 9 1 ...
- 【剑指Offer】01、二维数组中的查找
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...
随机推荐
- unittest之suite测试集(测试套件)
suite 这个表示测试集,不要放在class内,否则会提示"没有这样的测试方法在类里面 ",我觉得它唯一的好处就是调试的时候可以单独调试某个class而已,我一般不用它,调试时可 ...
- PAT乙级 1024. 科学计数法 (20)(未通过全部测试,得分18)
1024. 科学计数法 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 科学计数法是科学家用来表示很 ...
- 用js或css实现淡入淡出
淡入淡出?你问我有什么用? 提升首页13格的东西,你居然不知道!! 好啦,不废话了,正文. 1 js 主要元素:fadeIn() fadeOut() show hide 2 css 主要元素: o ...
- VS2010中如何实现自定义MFC控件
本文简要讲解在VS2010中怎样实现自定义MFC控件的知识,以下是分步骤说明. 一.自定义一个空白控件 1.先创建一个MFC工程 NEW Project-->MFC-->MFC Appl ...
- MyBatis学习笔记(三)——优化MyBatis配置文件中的配置
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4264301.html 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的 ...
- iPhone手机获取uuid 安装测试app
iPhone手机获取uuid 安装测试app UDID是一种iOS设备的特殊识别码.除序号之外,每台ios装置都另有一组独一无二的号码,我们就称之为识别码( Unique Device Identif ...
- [转载]论asp.net out、ref、return
论asp.net out.ref.return ref(引用类型) ref引用类型进出都必须赋值,赋值后会改变类型原来的指针. out(值类型) out值类型进可以不赋值,出必须赋值. r ...
- python之路----进程三
IPC--PIPE管道 #创建管道的类: Pipe([duplex]):在进程之间创建一条管道,并返回元组(conn1,conn2),其中conn1,conn2表示管道两端的连接对象,强调一点:必须在 ...
- linux环境下安装jdk1.6
卸载rpm版的jdk: #rpm -qa|grep jdk 显示:jdk1.6.0_29-fcs 卸载:#rpm -e --nodeps jdk1.6.0_29-fcs 1.从sun公司网站www.s ...
- (四)github之Git的初始设置
设置姓名与邮箱地址 这里的姓名和邮箱地址会用在git的提交日志之中,在github上公开git仓库时会随着提交日志一起公开. 有两种方式, 第一种,在git bash下设置 第二种, 通过直接编辑.g ...