本文實(shí)例為大家分享了python實(shí)現(xiàn)楊氏矩陣查找的具體代碼,供大家參考,具體內(nèi)容如下
創(chuàng)新互聯(lián)公司專注于烏恰企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站建設(shè)。烏恰網(wǎng)站建設(shè)公司,為烏恰等地區(qū)提供建站服務(wù)。全流程按需定制,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)問題描述:
在一個(gè)m行n列二維數(shù)組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請(qǐng)完成一個(gè)函數(shù),輸入這樣的一個(gè)二維數(shù)組和一個(gè)整數(shù),判斷數(shù)組中是否含有該整數(shù)。有則返回1,無(wú)則返回0,輸入錯(cuò)誤返回input error
問題分析:根據(jù)楊氏矩陣的規(guī)律可知,左上角是最小元素,右下角是大元素,進(jìn)行比較一次只能排除一個(gè)。而利用左下角或者右上角對(duì)比,一次可以排除一行或一列。
AC代碼以右上角為例:
代碼如下:
# coding=utf-8 import sys def solve(): try: # 獲取行(n)和列(m) a = sys.stdin.readline().split() n, m = int(a[0]), int(a[1]) arr = [] for i in range(n): # 列表模擬二維數(shù)組 p = list(map(int, sys.stdin.readline().split())) arr.append(p) # 獲取要查找的數(shù) s = int(sys.stdin.readline().strip()) i = 0 j = m - 1 while i=0: if arr[i][j] == s: # 相等返回1查找成功 return 1 elif arr[i][j] < s: # 小于要查找的元素,行加1 i += 1 else: # 大于要查找的元素,列加1 j -= 1 return 0 except Exception: return "input error" if __name__ == "__main__": print(solve())
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。