二维数组中的查找

来源:互联网 发布:360加固助手mac打不开 编辑:程序博客网 时间:2024/05/16 09:21

题目为:在二维数组中,每一行从左到右递增,每一列都从上到下递增,写一个函数,输入这样一个数组和一个整数,判断这个数组中是不是有这个数字:

思想:

1.基本思想,最笨无非就是遍历这个二维数组嘛

2.全部遍历的话,题目给的从左到右,从上到下的条件就没有用到,所以,全部遍历显然不合适

先来一张图:


图有点丑,意思到就行,来看,黑色箭头指向遍历的入口坐标,两个黑色箭头就说明,两种走的路径都是可以的,说一下,选择的理由,发现两个黑色箭头指向的坐标的值的或上或下或左或右都是有规律的,左下角的来说,上边的都比它小,右边的都比它大;不多说,直接上代码:

//a为数组,rows为行数,cols为列数,number为查找数//         row为行号, cols为列号bool Find(int* a, int rows, int cols, int number){bool found = false;if (a != nullptr && rows > 0 && cols > 0){int row = rows - 1;int col = 0;          //此两变量定位开始遍历的入口坐标while (row < rows && col >= 0){if (a[row*cols + col] > number)--row;          //如果当前坐标值比number大,上走else if (a[row*cols + col] < number)++col;          //如果当前坐标值比number小,右走else{found = true;break;}}}return found;}
这是左下角开始,再上一个右上角开始,内容差不多,不再过多描述,直接代码:

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
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 眼睛迷了怎么办小绝招 isf货物离港申报怎么办 非农户口没住房怎么办 在工厂上班很累怎么办 退货运费太贵了怎么办 悬肘写字手抖怎么办 护士成绩合格证明丢了怎么办 找工作真难找好烦怎么办 大夫说身体不适合怀孕有了怎么办 不知道要做什么工作怎么办 红米note4x闪退怎么办 魅蓝note3闪退怎么办 红米note2闪退怎么办 安卓不支持计步怎么办 银行多扣了钱怎么办 网络配置器没了怎么办 班里丢钱了应该怎么办 初级会计考过了怎么办 教师职称证丢了怎么办 会计初级证丢了怎么办 工作遭同事不满否认质疑怎么办 单位领导不让进收入财务怎么办 事业单位50岁不愿退休的怎么办 回美国i20丢了怎么办 i20忘签字美国入境怎么办 社保基数报错了怎么办 公司合同没给我怎么办 给客户报错价格怎么办 给客户报价低了怎么办 报价失误报低了怎么办 期望薪资说低了怎么办 期望薪资说高了怎么办 面试工资说低了怎么办 期望薪资谈低了怎么办 请年假公司不批怎么办 期望工资填低了怎么办 面试工资要高了怎么办 找工作期望薪资写低了怎么办 期望工资写少了怎么办 不给工人发工资怎么办 天亮了怎么办我好想你