python 二維數組長度_劍指offer二維數組中的查找【Java+Python】

點擊上方"藍字",關注了解更多fc6e87cc3277aa6ddeebf5f888fdcb71.png

二維數組中的查找

1. 題目描述

在一個二維數組中(每個一維數組的長度相同),每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數,輸入這樣的一個二維數組和一個整數,判斷數組中是否含有該整數。

2. 示例

現有矩陣 matrix 如下:

[ [1, 4, 7, 11, 15],

[2, 5, 8, 12, 19],

[3, 6, 9, 16, 22],

[10, 13, 14, 17, 24],

[18, 21, 23, 26, 30] ]

給定 target = 5,返回 true。

給定 target = 20,返回 false。

3. 解題思路

使用以下方法的前提是:該矩陣是有序的。

從矩陣的左下角開始搜索,即從18 開始查找,如果該數大于目標數,則 行數 減去 1,向上搜索小的數值;

如果小于目標數,則 列數 + 1 ,向右邊搜索,搜索更大的數值

4. Java實現

//?Java語言實現
public?class?Solution?{
????public?boolean?Find(int?target,?int?[][]?array)?{
????????int?row?=?array.length-1;
????????int?col?=?0;??
????????//?從左下角開始搜索,array.length?表示行的大小,array[0].length表示列的大小
????????
????????while?(row?>=?0?&&?col?<=?array[0].length-1){
????????????if?(array[row][col]?==?target){
????????????????return?true;
????????????}else?if(array[row][col]?>?target){
????????????????row--;
????????????}else{
????????????????col++;
????????????}
????????????
????????}
????????return?false;
?
????}
}

5. Python實現

class?Solution(object):
????def?searchMatrix(self,?matrix,?target):
????????"""
????????:type?matrix:?List[List[int]]
????????:type?target:?int
????????:rtype:?bool
????????"""
????????
????????if?not?matrix:
????????????return?False
????????
????????rows,?cols?=?len(matrix),?len(matrix[0])
????????#從左下角開始搜索
????????row,?col?=?rows?-?1,?0
????????while?row?>=?0?and?col?<=?cols-1:
????????????if?matrix[row][col]?==?target:
????????????????return?True?
????????????elif?matrix[row][col]?????????????????col?+=?1
????????????else:
????????????????row?-=?1?#?row一直減少
????????return?False

如果您覺得本文有用,請點個“在看”

88fd3a8146d825b9082b8b632ee8ab81.png精彩推薦

Java開發微服務暢購商城實戰-全357集【附代碼課件】

Java微服務實戰谷粒商城-296集【附代碼課件】

Spring Boot開發小而美的個人博客【附課件和源碼】

基于Python flask框架的租房項目實戰【附資料和源碼】

PyQt5開發與實戰視頻【附課件和源碼】

最全最詳細數據結構與算法視頻-【附課件和源碼】

2020年微信小程序全棧項目之喵喵交友【附課件和源碼】

b03c56b850148ff93d4c8c8ffa7f4a31.png? ? ? ? ? ? ? ? ? ? ??

你點的每一個在看,我都認真當成了喜歡

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/528931.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/528931.shtml
英文地址,請注明出處:http://en.pswp.cn/news/528931.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

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)# 創建添加一個文…

php 模塊 遠程,ThinkPHP遠程調用模塊的操作方法 URL 參數格式

* 遠程調用模塊的操作方法 URL 參數格式 [項目://][分組/]模塊/操作* param string $url 調用地址* param string|array $vars 調用參數 支持字符串和數組* param string $layer 要調用的控制層名稱* return mixedfunction R($url,$varsarray(),$layer‘‘) {$info pathinfo($…

python3 csv 讀入數組_如何將CSV數據讀入NumPy中的記錄數組?

我建議read_csv函數的pandas圖書館&#xff1a;import pandas as pddfpd.read_csv(myfile.csv, sep,,headerNone)df.valuesarray([[ 1. , 2. , 3. ],[ 4. , 5.5, 6. ]])DataFrame是一種具有潛在不同類型列的二維標記數據結構.你可以把它想象成一個電子表格或SQL表.我也建議…

php用cdn打不開,開啟 CDN 后 wordpress 后臺打不開的解決辦法

現在很多站長把網站放到國外&#xff0c;使用 CDN 加速功能提高國內的訪問速度&#xff0c;前面提到過開啟騰訊云 CDN 后 wordpress 后臺顯示&#xff1a;連接被重置的解決辦法&#xff0c;而今天遇到的是另外一種情況&#xff0c;有時候會遇到開啟 CDN 后 wordpress 后臺打不開…

android 支付寶月賬單 統計圖_記賬其實很簡單,用微信、支付寶就夠了!

用微信、支付寶記賬&#xff0c;從起告別糊涂賬養成記賬的好習慣&#xff0c;能讓你對生活中的各種收支做到心中有數&#xff0c;從此告別糊涂賬。長期堅持&#xff0c;能幫助我們理性消費、科學理財。但或許是因為記賬的過程太枯燥&#xff0c;或許是因為沒找到合適的記賬方法…

mysql抖動可能的原因,12 | 為什么我的MySQL會“抖”一下?

你的 SQL 語句為什么變“慢”了平時執行很快的更新操作&#xff0c;其實就是在寫內存和日志&#xff0c;而 MySQL 偶爾“抖”一下的那個瞬間&#xff0c;可能就是在刷臟頁(flush)。當內存數據頁跟磁盤數據頁內容不一致的時候&#xff0c;我們稱這個內存頁為“臟頁”。內存數據寫…

怎樣快速畫出一個正方體_圖形與幾何---正方體

一&#xff0e;概念描述現代數學&#xff1a;正方體亦稱立方體。它是一種正多面體。即棱長相等的長方體&#xff0c;因此亦稱正六面體&#xff0c;如下圖。小學數學&#xff1a;2007年北京版教材第10冊的第3頁指出&#xff1a;長、寬、高都相等的長方體叫作正方體(也叫作立方體…

python argvparser_Python ArgumentParse的subparser用法說明

在寫一些很小的機器學習項目的時候,我們往往希望training, testing和inference能共用一個入口main,但是不同的功能使用不同的input參數.當然如果三個功能對應三個.py腳本問題也不大,但是畢竟覺得不太優雅.這個時候就需要考慮如何讓代碼更加簡單有條理.主要是最近在看parser有關…