[Python數(shù)據(jù)結(jié)構(gòu)與算法] 1. 二維數(shù)組的查找

在一個二維數(shù)組中(每個一維數(shù)組的長度相同)褐奥,每一行都按照從左到右遞增的順序排序仰挣,每一列都按照從上到下遞增的順序排序冒冬。請完成一個函數(shù)伸蚯,輸入這樣的一個二維數(shù)組和一個整數(shù),判斷數(shù)組中是否含有該整數(shù)简烤。
時間限制:1秒 空間限制:32768K
偶劣剩客網(wǎng) Online Test

方法 1(我第一感覺的寫法,好瓜昂嵴臁): list.count(target)

class Solution:
    def Find(self, target, array):
        for i in range(len(array)):
            if array[i].count(target)>0:
                return True
        return False
time (ms) memory (kB)
443 6060

方法 2 (張學(xué)志): if target in list

class Solution:
    def Find(self, target, array):
        flag = False
        for index in range(len(array)):
            if target in array[index]:
                flag = True
        return flag
time (ms) memory (kB)
438 6044

方法1和方法2都是調(diào)用python標(biāo)準(zhǔn)庫函數(shù)挥萌,底層實現(xiàn)是一樣的。

方法2改進版:

class Solution:
    def Find(self, target, array):
        for index in range(len(array)):
            if target in array[index]:
                return True
        return False
time (ms) memory (kB)
403 5880

如果在array中有好幾個和target一樣的元素枉侧,方法1和方法2都可能遍歷到每個相同元素引瀑,而方法2改進版遍歷到第一個相同目標(biāo)元素就break了。在這種特殊情況下榨馁,方法2改進版會稍微快一點憨栽。顯然,這兩種方法都沒有利用題目所示的二維數(shù)組的性質(zhì):

  • 每個一維數(shù)組長度相同翼虫;
  • 從左至右屑柔,從上至下遞增。

方法3 (張學(xué)志):利用題中數(shù)組的特性

table
A B C (start)
D E F
F (stop) G H

假設(shè)有兩個指針珍剑,分別是行和列掸宛,從右上角開始遍歷,
如果target<C招拙,則target<列{CFH}旁涤,列指針左移到B;
如果target<B翔曲,列指針繼續(xù)左移,反之劈愚,則行指針下移。

如果target>C闻妓,則target>行{ABC}菌羽,行指針下移到F;
如果target<F由缆,列指針左移注祖,反之,行指針繼續(xù)下移均唉。

有點暈是晨?

  • start:右上
  • target<element,列指針-- (左移)
  • target>element舔箭,行指針++(下移)
  • stop:左下

舉個實例

table
1 2 8
3 4 9
9 10 12
target=7
1 (step 2) 7>2 (step 1) 7<8
3 (step 3) 7>4 9
(step 5) 7<9 (stop) (step 4) 7<10 12

不存在

target=10
1 2 (step 1) 10>8
3 7>4 (step 2) 10>9
9 (step 4) 10==10 (stop) (step 3) 10<12

存在

class Solution:
   def Find(self, target,array ):
       nrow = len(array)
       ncol = len(array[0])
       row = 0
       col = ncol-1
       while row<nrow and col>=0:
           if target == array[row][col]:
               return True
           elif target > array[row][col]:
               row += 1
           else:
               col -= 1
       return False
time (ms) memory (kB)
182 5728

時間復(fù)雜度對比 (對于m行*n列的數(shù)組)

方法 大O
方法1 m*n
方法2 m*n
方法3 m+n-1

總結(jié)

題目本身不限制語言的罩缴,應(yīng)該是希望coder考慮時空復(fù)雜度以及數(shù)組本身的特性。如果選擇用python层扶,那么方法2改進版應(yīng)該是最pythonic的寫法箫章,簡單易懂。具體選擇什么方法取決于現(xiàn)實數(shù)據(jù)量的大小镜会。如果真的要極致的performance檬寂,還是用C吧,哈哈戳表。

參考

python list 函數(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桶至,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子匾旭,更是在濱河造成了極大的恐慌镣屹,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件季率,死亡現(xiàn)場離奇詭異野瘦,居然都是意外死亡,警方通過查閱死者的電腦和手機飒泻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門鞭光,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人泞遗,你說我怎么就攤上這事惰许。” “怎么了史辙?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵汹买,是天一觀的道長佩伤。 經(jīng)常有香客問我,道長晦毙,這世上最難降的妖魔是什么生巡? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮见妒,結(jié)果婚禮上孤荣,老公的妹妹穿的比我還像新娘。我一直安慰自己须揣,他們只是感情好盐股,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耻卡,像睡著了一般疯汁。 火紅的嫁衣襯著肌膚如雪茬斧。 梳的紋絲不亂的頭發(fā)上陪腌,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天,我揣著相機與錄音靠抑,去河邊找鬼凛澎。 笑死霹肝,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的塑煎。 我是一名探鬼主播沫换,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼最铁!你這毒婦竟也來了讯赏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤冷尉,失蹤者是張志新(化名)和其女友劉穎漱挎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體雀哨,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡磕谅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了雾棺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膊夹。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖捌浩,靈堂內(nèi)的尸體忽然破棺而出放刨,到底是詐尸還是另有隱情,我是刑警寧澤尸饺,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布进统,位于F島的核電站助币,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏螟碎。R本人自食惡果不足惜眉菱,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望抚芦。 院中可真熱鬧倍谜,春花似錦、人聲如沸叉抡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽褥民。三九已至,卻和暖如春洗搂,著一層夾襖步出監(jiān)牢的瞬間消返,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工耘拇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留撵颊,地道東北人。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓惫叛,卻偏偏與公主長得像倡勇,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子嘉涌,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容

  • 題目: 在一個二維數(shù)組中妻熊,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序仑最。請完成一個函數(shù)扔役,...
    clshinem閱讀 298評論 0 1
  • 題目描述在一個二維數(shù)組中亿胸,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序预皇。請完成一個函數(shù)侈玄,...
    juexin閱讀 690評論 0 0
  • “小時候的我還在糾結(jié)該上清華還是北大拗馒,可是長大后才發(fā)現(xiàn)原來我想多了∷萁郑” 最近總有很多的人問诱桂,上一個好大學(xué)真的很重要...
    安生的小世界閱讀 1,512評論 0 1
  • 小小的醫(yī)院里洋丐,每天都在發(fā)生著或溫馨或氣憤或揶揄的小故事。這就是人生千態(tài)挥等,不分你我的存在的故事友绝。 今天媽媽要開始做第...
    Galaxy星辰里閱讀 660評論 0 1
  • 在我看過的與科幻和愛情相關(guān)的電影當(dāng)中,印象最深的肝劲,就是日本電影《我的機器人女友》迁客。 看這部電影的前半部分,會覺得它...
    溪邊孤樹閱讀 515評論 0 0