隔一段時間查找一次 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.pswp.cn/news/528938.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/528938.shtml
英文地址,請注明出處:http://en.pswp.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)# 創建添加一個文…