隔一段时间查找一次 golang_剑指 offer-04 二维数组中的查找

7c11c73f42990a365808afd41e3ee10f.png

算法名称:二维数组中的查找

题目内容:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

解题思路:

首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程结束;如果该数字大于要查找的数字,剔除这个数字所在的列;如果该数字小于要查找的数字,剔除这个数字所在的行。也就是说如果要查找的数字不在数组的右上角,则每一次都在数组的查找范围中剔除一行或者一列,这样每一步都可以缩小查找的范围,直到找到要查找的数字,或者查找范围为空。

例如,我们要在上述的二维数组中查找数字7的步骤如下图所示:

6c517895a439d8332324f47330b46e2a.png

实例代码:

  • Java
class Solution {public boolean findNumberIn2DArray(int[][] matrix, int target) {if (matrix.length > 0 && matrix[0].length > 0) {int row = 0;int colomn = matrix[0].length - 1;while (row < matrix.length && colomn >= 0) {if (target < matrix[row][colomn]) {colomn--;} else if (target > matrix[row][colomn]) {row++;} else if (target == matrix[row][colomn]) {return true;}}}return false;}}
  • Golang版
func findNumberIn2DArray(matrix [][]int, target int) bool {if len(matrix) > 0 && len(matrix[0]) > 0 {row := 0colomn := len(matrix[0]) - 1for row < len(matrix) && colomn >= 0 {if target < matrix[row][colomn] {colomn--} else if target > matrix[row][colomn] {row++} else if target == matrix[row][colomn] {return true}}}return false}

本题考点:

  • 考察面试者对二维数组的理解及编程能力。二维数组在内存中占据连续的空间。在内存中从上到下存储各行元素,在同一行中按照从左到右的顺序存储。因此我们可以根据行号和列号计算出相对于数组首地址的偏移量,从而找到对应的元素。

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

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

相关文章

decorator php,php设计模式 Decorator(装饰模式)

/*** 装饰模式** 动态的给一个对象添加一些额外的职责,就扩展功能而言比生成子类方式更为灵活*/header("Content-type:text/html;charsetutf-8");abstract class MessageBoardHandler{public function __construct(){}abstract public function filter($msg);}class …

python中format函数用法简书_增强的格式化字符串format函数

自python2.6开始&#xff0c;新增了一种格式化字符串的函数str.format()&#xff0c;可谓威力十足。那么&#xff0c;他跟之前的%型格式化字符串相比&#xff0c;有什么优越的存在呢&#xff1f;让我们来揭开它羞答答的面纱。它通过{}和:来代替%。“映射”示例通过位置In [1]: …

在线电脑配置PHP源码,域名授权系统PHP源码 V2.7.0 支持盗版追踪

最新漂亮简洁大气的域名授权系统PHP源码&#xff0c;域名授权系统PHP版&#xff0c;功能强大带有后台&#xff0c;经过版本升级&#xff0c;全新美观大气的UI洁面&#xff01;支持盗版追踪&#xff0c;与卡密系统对接购买卡密对域名进行授权&#xff0c;支持授权代码、到期时间…

python分词代码_中文分词--最大正向匹配算法python实现

最大匹配法&#xff1a;最大匹配是指以词典为依据&#xff0c;取词典中最长单词为第一个次取字数量的扫描串&#xff0c;在词典中进行扫描(为提升扫描效率&#xff0c;还可以跟据字数多少设计多个字典&#xff0c;然后根据字数分别从不同字典中进行扫描)。例如&#xff1a;词典…

python输出所有组合数_python – GridSearchCV是否存储了所有参数组合的所有分数?...

GridSearchCV使用“评分”来选择最佳估算器.训练GridSearchCV后,我希望看到每个组合的得分. GridSearchCV是否存储每个参数组合的所有分数&#xff1f;如果它如何获得分数&#xff1f;谢谢.这是我在另一篇文章中使用的示例代码.from sklearn.feature_extraction.text import Co…

php 504网关,504 gateway timeout什么意思

504 gateway time-out(504网关超时错误)是HTTP状态代码&#xff0c;这意味着一个服务器在尝试加载网页或填写浏览器的另一个请求时未从其访问的另一台服务器收到及时响应。换句话说&#xff0c;504错误通常表明不同的计算机&#xff0c;即您正在获取504消息的网站无法控制但依赖…

python 二维数组长度_剑指offer二维数组中的查找【Java+Python】

点击上方"蓝字"&#xff0c;关注了解更多二维数组中的查找1. 题目描述在一个二维数组中(每个一维数组的长度相同)&#xff0c;每一行都按照从左到右递增的顺序排序&#xff0c;每一列都按照从上到下递增的顺序排序。请完成一个函数&#xff0c;输入这样的一个二维数组…

php 静态变量 引用,PHP的返回引用(方法名前加)和局部静态变量(static)

先阅读手册从函数返回一个引用&#xff0c;必须在函数声明和指派返回值给一个变量时都使用引用操作符 & &#xff1a;例子 17-13. 由函数返回一个引用有关引用的更多信息, 请查看引用的解释。在来看一段很多开源代码喜欢用的单例注册模式 class a{} class b{} function &am…

失物招领小程序_通知 | 保卫部拟设置失物招领处

保卫部拟设置失物招领处为规范对遗失物品的接收、登记、发放等工作&#xff0c;切实维护师生利益&#xff0c;保卫部拟设置失物招领处&#xff0c;现将有关失物招领的流程明确如下&#xff1a;1、失物招领地点&#xff1a;保卫部二楼中厅。2、遗失物的接收。师生将拾得的遗失物…

php获取表所有数据类型,php excel 导入 导入三级分类 表格应该怎么设计才能得到想要的数据格式?...

就是多个1级分类 下面有不确定个二级分类 二级分类下面有不确定个三级分类 我想获取到相关的数据组合写入数据库 但是这个格式不知道怎么排才能获取到对的数据有空的亲们给看看 帮下 谢谢有没有办法获取整列的值 然后根据长度去区分2列 然后再区分三列现在获取到的数据格式是按…

python数据清理的实践总结_python3常用的数据清洗方法(小结)

首先载入各种包&#xff1a;import pandas as pdimport numpy as npfrom collections import Counterfrom sklearn import preprocessingfrom matplotlib import pyplot as plt%matplotlib inlineimport seaborn as snsplt.rcParams[font.sans-serif] [SimHei] # 中文字体设置…

转转钓鱼php,最新转转钓鱼源码程序网站微信:mm88wk 最新转转源码 - 下载 - 搜珍网...

压缩包 : 转转钓鱼源码微&#xff1a;mm88wk.zip 列表转转/转转/360safe/转转/360safe/360webscan.php转转/360safe/webscan_cache.php转转/admin/转转/admin/add.php转转/admin/addsite.php转转/admin/adduser.php转转/admin/downfile.php转转/admin/download.php转转/admin/e…

PHP即将退出,PHP4即将退出历史舞台

http://www.phpeye.com/bbs/viewthread.php?tid92 PHP官方团队在php.net上发布了一则公告&#xff1a; Today it is exactly three years ago since PHP 5 has been released. In those three years it has seen many improvements over PHP 4. PHP 5 is fast, stablehttp://w…

redis 清空db下_PHP操作redis实现的分页列表

正文内容封装类文件如下&#xff1a;/* * redis 分页数据类库 */class redisPage{protected $_redis;protected $_redis_ip 127.0.0.1; //ipprotected $_redis_port 6379; //端口protected $_redis_db 0; //数据库号protected $_hash_prefix my_data; //前缀名称public fun…

php5.1.4,apache 2.2.2 + PHP5.1.4 不能运行的解_php

apache 2.2.2 php5.1.4 不能运行的解决办法.问题,使用传统的模块化方法安装PHP5.1.* apache 2.2.2 后不能启动,提示:"Cannot load C:/php/php5apache2.dll into server: The specified module could not be found."原因:PHP压缩包里的php5apache2.dll只适用于apach…

python3中的zip_Python3实现将文件归档到zip文件及从zip文件中读取数据的方法

Created on Dec 24, 2012将文件归档到zip文件&#xff0c;并从zip文件中读取数据author: liury_lab# 压缩成zip文件from zipfile import * #UnusedWildImportimport osmy_dir d:/中华十大名帖/myzip ZipFile(d:/中华十大名帖.zip, w, ZIP_DEFLATED)for file_name in os.listd…

java mariadb 使用,java连接mariaDB的设置,java连接mariadb

java连接mariaDB的设置&#xff0c;java连接mariadbjava连接mariaDB数据库的设置&#xff1a;(tomcat 8)第一种方法&#xff1a;使用tomcat自带的mysql-connector-java-5.1.40-bin.jarjava代码中的设置&#xff1a;driver驱动类为&#xff1a;com.mysql.jdbc.Driverurl为&#…

python产品发布会_【Mac系统 + Python + Django】之开发一个发布会系统【Django模型(三)】...

上一部分给大家介绍Django的视图。接下来继续来了解Django框架&#xff0c;来看第三部分&#xff0c;此部分是对数据库的操作。目录&#xff1a;一、设计系统表            返回目录首先打开sign/models.py&#xff0c;通过模型完成标的创建&#xff1a;from djang…

java 保留字符串,如何在Java中保留字符串而不使用反转功能

有以下几种在Java中反转字符串的方法&#xff1a;使用for循环使用While循环使用静态方法使用For循环使用for循环在Java中反转字符串的示例在下面的示例中, 我们使用了for循环来反转字符串。 for循环执行直到条件i> 0变为false为止。import java.util.Scanner;class ReverseS…

python增删改查csv文件_Python增删改查文件

#!/usr/bin/env python# -*- coding:utf-8 -*-# author:Erik Chan# datetime:2018/12/27 9:29# software: PyCharmimport os# 获取当前文件的父目录文件夹DIR os.path.dirname(os.path.abspath(__file__))cwd os.getcwd() #获取当前目录即dir目录下print(cwd)# 创建添加一个文…