Java利用二维数组判断节假日_《剑指offer》面试题3 二维数组中的查找 Java版

(二维数组,每行递增,每列递增。输入二维数组和一个整数,判断数组中是否含有此数。)

我的方法:拿到题目,根据题目条件我提取出这样一个特性:一个数的右边和下面的数都比它大。于是就可以写出一种递归的方法:从左上角开始寻找,针对当前被检查的数字,如果相等返回true;如果小于target我们继续向右和向下寻找;如果大于target就不必继续寻找下去了(因为我们向右或向下寻找只会继续增大)。

public class SearchIn2DArray {

public static boolean find(int[][] a, int target){

// 指针为空 或者 {}或者{{}}

if(a == null || a.length == 0 || (a.length == 1 && a[0].length == 0)){

return false;

}

return search(a, target, 0, 0);

}

private static boolean search(int[][] a, int target, int row, int col){

if(row >= a.length || col >= a[0].length){

return false;

}

if(a[row][col] > target){

return false;

}else if(a[row][col] == target){

return true;

}else return search(a, target, row+1, col) || search(a, target, row, col+1);

}

}

书中方法:解决复杂问题,一个很有效的方法是从一个具体的问题入手,通过分析简单的例子,寻找到普通的规律。书上的思路是从右上角开始,向左或者向下去寻找目标,也是利用了左边的数字比当前数字小,下面的数字比当前数字大这个特点。

public class SearchIn2DArray {

public boolean find2(int[][] a, int target){

if(a == null || a.length == 0 || (a.length == 1 && a[0].length == 0)){

return false;

}

int rowNow = 0;

int colNow = a[0].length-1;

while(rowNow < a.length && colNow >= 0){

if(a[rowNow][colNow] == target){

return true;

}else if(a[rowNow][colNow] > target){

rowNow ++;

}else if(a[rowNow][colNow] < target){

colNow --;

}

}

return false;

}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/551358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多表关联查询_【函数007】 EXCEL多表关联查询实战

继续函数实战系列教程&#xff0c;今天要分享的案例是根据填写的表名自动提取对应表中的数据数据准备&#xff1a;需求说明&#xff1a;我们希望实现&#xff0c;我们选择不同月份&#xff0c;显示对应月份表中的数据&#xff01;处理方案&#xff1a;1、构建下拉列表(菜单)数据…

java if emun_关于java:Enum与If-else

我有一个需求&#xff0c;其中我需要从事件列表中构建如下的雇员对象。 目前&#xff0c;我的代码如下所示&#xff0c;但是QE发表评论说可能使用枚举而不是多个。有人可以建议我如何用枚举实现这一点。Employee e new Employee();for(Event event:events){if("empid"…

管理动物园动物c++_《过山车大亨》开发商公开新作 建立自己的动物园

知名模拟经营游戏开发商Frontier Developments近日宣布&#xff0c;旗下游戏《动物园之星》(Planet Zoo)即将在不久后发售&#xff0c;登录Steam平台。本座是一款模拟经营游戏&#xff0c;玩家在游戏中将会从零开始&#xff0c;建立一个属于自己的动物园世界。游戏中有多种不同…

Java_数组练习答案_Java数组练习题带答案.doc

《Java数组练习题带答案.doc》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《Java数组练习题带答案.doc(11页珍藏版)》请在人人文库网上搜索。1、一 填空题1) 数组的元素通过 下标 来访问&#xff0c;数组Array的长度为 Array.length 。2) 数组复制时&#xff0c;将一…

安费诺amphenol连接器_安费诺的Ellison谈信号完整性职业和他的免费开源PCB设计软??件...

Amphenol的信号完整性工程师杰森埃里森(Jason Ellison )Amphenol(安费诺) ICC的高级职员信号完整性工程师杰森埃里森(Jason Ellison )深入了解了网络&#xff0c;给予EE(电子)社区以及他的开源信号完整性项目的重要性。信号完整性工程与其他EE(电子)领域相比如何&#xff1f;他…

python形参和实参命名方式_Python的形参和实参使用方式

Python的形参和实参使用方式形参可以设置参数默认值&#xff0c;设置遵循从右至左原则例如&#xff1a;fun(x0,y1),fun(x,y1)&#xff0c;但不可以是fun(x1,y)形参设置可以为数字字符串变量、元组和字典等任意类型数据&#xff0c;元组形参是在变量名前加*&#xff0c;字典形参…

mysql的contains_mysql中json_contains、json_extract等json查询方法的使用

新版 Mysql 中加入了对 JSON Document 的支持&#xff0c;可以创建 JSON 类型的字段&#xff0c;并有一套函数支持对JSON的查询、修改等操作。JSON是一种轻量级的数据交换格式&#xff0c;采用了独立于语言的文本格式&#xff0c;类似XML&#xff0c;但是比XML简单&#xff0c;…

260多媒体语言如何调节_260马力配9.7米货厢,实拍柳汽H5小三轴载货车

【卡车之家 原创】高速公路按轴的收费实施让9米6大单桥载货车火了起来&#xff0c;能够满足快递快运、电商物流等以方量为主的轻型货物运输。但这种大单桥18吨的限重对于不少卡友来说或许不太够用&#xff0c;而8x4载货车又有些大材小用了。这时&#xff0c;处于中间位置的三轴…

php mysql复杂查询_半复杂的PHP / MySQL Select语句

我目前有3张桌子,我正在用这些桌子来预定某些设备.这是我的桌子&#xff1a;tblEquipment:id name description1 Camera Takes pictures2 Projector Projects pictures3 Laptop Portable ComputertblEvents:id start end first_name last_name email1 2009-08-10 2009-08-11 Jo…

python获取网络信息_利用psutil获取网络信息

获取网络总的io信息[rootbogon python_auto]# vim net.py!/usr/bin/env pythonimport psutilnet_information psutil.net_io_counters()print net_information执行查看网络信息[rootbogon python_auto]# python net.pysnetio(bytes_sent29111743, bytes_recv396060467, packet…

java dispatcher详解_dispatcherservlet初始化过程详解

之前给大家介绍了什么是dispatcherservlet&#xff0c;以及dispatcherservlet配置等方面的内容&#xff0c;那么下面要接着给大家介绍的就是dispatcherservlet初始化过程&#xff0c;一起来了解一下。Web容器启动时将调用HttpServletBean的init方法public abstract class HttpS…

python消息队列模块_day43-python消息队列二-queue模块

Python提供了Queue模块来专门实现消息队列Queue对象Queue对象实现一个fifo队列(其他的还有lifo、priority队列&#xff0c;这里不再介绍)。queue只有maxsize一个构造参数&#xff0c;用来指定队列容量&#xff0c;指定为0的时候代表容量无限。主要有以下成员函数&#xff1a;Qu…

linux php 如何上传webshell,linux+apache+php的一次拿webshell的心得

首先俺先声明俺是个菜鸟&#xff0c;俺虽然是菜鸟但俺不会一直是菜鸟的(一旁兄弟喊到&#xff1a;别俺&#xff0c;俺&#xff0c;俺的&#xff0c;说普通话&#xff01;)。俺&#xff0c;不对&#xff0c;我一直遵照着实践是检验真理的唯一标准这句话学习技术&#xff0c;这不…

paddle 56 将图像分类模型嵌入到目标检测中并实现端到端的部署(用图像分类模型进行目标检测切片分类)

目标检测在功能上一直是涵盖了图像分类的,其包含目标切片检测,目标切片分类。由于某些原因,需要将目标检测的功能退化为检测,忽略其切片分类,使用外部的分类模型。然而这样操作会使得其与原始的部署代码不兼容,为此博主实现将图像分类模型嵌入到目标检测中,并实现端到端…

python3图像识别地类_机器学习零基础?手把手教你用TensorFlow搭建图像识别系统(三)| 干货...

原标题&#xff1a;机器学习零基础?手把手教你用TensorFlow搭建图像识别系统(三)| 干货雷锋网按&#xff1a;本文是介绍用TensorFlow构建图像识别系统的第三部分。 在前两部分中&#xff0c;我们构建了一个softmax分类器来标记来自CIFAR-10数据集的图像&#xff0c;实现了约25…

织梦php重新安装教程,织梦CMS系统后台重装的操作教程

原标题&#xff1a;织梦CMS系统后台重装的操作教程网站在线运行&#xff0c;不可能一点问题都不存在&#xff0c;或者当初的网站设计、架构、功能已经不能满足现在用户的需求&#xff0c;所以我们会对网站做出相应的改动。网站除了前端的改版&#xff0c;还会有后台系统重装、服…

mpu9250姿态融合算法_基于投票方式的机器人装配姿态估计

作者&#xff1a;仲夏夜之星来源&#xff1a;公众号 3D视觉工坊链接&#xff1a;基于投票方式的机器人装配姿态估计论文题目&#xff1a;《Voting-Based Pose Estimation for Robotic Assembly Using a 3D Sensor》这篇文章被发表在2012年的IEEE International Conference on R…

java安卓浏览器下载文件,JAVA实现文件下载,浏览器端得到数据没反应解决方案

JAVA实现文件下载,浏览器端得到数据没反应代码如下public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {//得到要下载的文件名称String filenamerequest.getParameter("filename");//文件存放的路径…

python如何读取kepsever_python linecache读取过程

最近使用Python编写日志处理脚本时&#xff0c;对Python的几种读取文件的方式进行了实验。其中&#xff0c;linecache的行为引起了我的注意。Python按行读取文件的经典方式有以下几种&#xff1a;with open(blabla.log, r) as f:for line in f.readlines():## do somethingwith…

skywalking原理_微服务链路追踪原理

作者&#xff1a;平也来源&#xff1a;关爱程序员社区背景介绍在微服务横行的时代&#xff0c;服务化思维逐渐成为了程序员的基本思维模式&#xff0c;但是&#xff0c;由于绝大部分项目只是一味地增加服务&#xff0c;并没有对其妥善管理&#xff0c;当接口出现问题时&#xf…