西安 网站建设 费用,西丽网站建设设计,WordPress建站怎么交付,做精彩网站分析的方向是前言
个人推荐在牛客网刷题(点击可以跳转)#xff0c;它登陆后会保存刷题记录进度#xff0c;重新登录时写过的题目代码不会丢失。个人刷题练习系列专栏#xff1a;个人CSDN牛客刷题专栏。 题目来自#xff1a;牛客/题库 / 在线编程 / 剑指offer#xff1a; 目录前言问题…前言
个人推荐在牛客网刷题(点击可以跳转)它登陆后会保存刷题记录进度重新登录时写过的题目代码不会丢失。个人刷题练习系列专栏个人CSDN牛客刷题专栏。 题目来自牛客/题库 / 在线编程 / 剑指offer 目录前言问题描述举例解法思路代码结果结束语问题描述
在一个二维数组array中每个一维数组的长度相同每一行都按照从左到右递增的顺序排序每一列都按照从上到下递增的顺序排序。请完成一个函数输入这样的一个二维数组和一个整数判断数组中是否含有该整数。 [ [1,2,8,9], [2,4,9,12], [4,7,10,13], [6,8,11,15] ] 给定 target 7返回 true。给定 target 3返回 false。数据范围矩阵的长宽满足0≤nm≤500,矩阵中的值满足0≤val≤10^9数据范围0≤n≤10000进阶时间复杂度O(1)空间复杂度Onm 举例
//示例1
//输入
7,[[1,2,8,9],[2,4,9,12],[4,7,10,13],[6,8,11,15]]
//返回值
true
//说明存在7返回true
//
//示例2
//输入
1,[[2]]
//返回值
false
//
//示例3
//输入
3,[[1,2,8,9],[2,4,9,12],[4,7,10,13],[6,8,11,15]]
//返回值
false
//说明不存在3返回false 解法思路
例题如图所示array[iRow][iCol]target 7 从右上角array[0][3]开始查找如果比target大则iCol– 第二步与array[0][2]开始对比比target大继续iCol– 第三步与array[0][1]开始对比比target小则iRow 第四步与array[1][1]开始对比比target小则iRow 第五步与array[2][1]开始对比等于target返回true 代码结果
/*** 代码中的类名、方法名、参数名已经指定请勿修改直接返回方法规定的值即可** * param target int整型 * param array int整型二维数组 * param arrayRowLen int array数组行数* param arrayColLen int* array数组列数* return bool布尔型** C语言声明定义全局变量请加上static防止重复定义*/
bool Find(int target, int** array, int arrayRowLen, int* arrayColLen ) {// write code hereint iRow 0;int iCol 0;bool bIsFind false;if (NULL array)return false;iCol *arrayColLen - 1;iRow 0;while (iCol 0 iRow arrayRowLen){if (target array[iRow][iCol]){bIsFind true;break;}else if (target array[iRow][iCol]){iCol--;}else{iRow;}}return bIsFind;
} 结束语
以上就是该C语言编程题的内容。可以在牛客尝试刷几道题目来练习实践。牛客网刷题(点击可以跳转)可以尝试注册使用。题目来自牛客/题库 / 在线编程 / 剑指offer