ARTS 06


Algorithm 74. 搜索二維矩陣

編寫一個(gè)高效的算法來(lái)判斷 m x n 矩陣中挖滤,是否存在一個(gè)目標(biāo)值糙置。該矩陣具有如下特性:

  • 每行中的整數(shù)從左到右按升序排列踱蛀。
  • 每行的第一個(gè)整數(shù)大于前一行的最后一個(gè)整數(shù)阱飘。

示例 1:

輸入:
matrix = [
[1, 3, 5, 7],
[10, 11, 16, 20],
[23, 30, 34, 50]
]
target = 3
輸出: true

示例 2:

輸入:
matrix = [
[1, 3, 5, 7],
[10, 11, 16, 20],
[23, 30, 34, 50]
]
target = 13
輸出: false

public boolean searchMatrix(int[][] matrix, int target) {
        if(matrix.length == 0 || matrix[0].length == 0){
            return false;
        }
        //右上角元素開始
        int i = 0;
        int j = matrix[0].length - 1;
        
        while(i < matrix.length && j >= 0){
            if(target == matrix[i][j]){
                return true;
            }
            if(target > matrix[i][j]){
                i++;
            }else{
                j--;
            }
        }
        return false;
    }

算法思路:
二維數(shù)組是有序的,從右上角來(lái)看,向左數(shù)字遞減,向下數(shù)字遞增轴踱。
因此從右上角開始查找,

當(dāng)要查找數(shù)字比右上角數(shù)字大時(shí)谚赎,下移淫僻;
當(dāng)要查找數(shù)字比右上角數(shù)字小時(shí),左移壶唤;
如果出了邊界嘁傀,則說(shuō)明二維數(shù)組中不存在該整數(shù)。


Review Lambdas不是函數(shù)式編程

Lambda表達(dá)式是Java SE 8中包含的一個(gè)新的重要特性。它們提供了一種使用表達(dá)式表示一個(gè)方法接口的簡(jiǎn)潔方法辅斟。Lambda表達(dá)式還改進(jìn)了Collection庫(kù)姐军,使其更容易迭代儒将,過(guò)濾和提取數(shù)據(jù)Collection员舵。此外工扎,新的并發(fā)功能可提高多核環(huán)境的性能泪酱。

Java的土地中沒有人正在進(jìn)行函數(shù)式編程钓觉,這是一件好事茴肥。

Java中的Lambda表達(dá)式只是一種不那么冗長(zhǎng)的創(chuàng)建(略微受限制)對(duì)象的方式,因此在沒有很好地理解核心功能概念的情況下采用Lambda的最可能的結(jié)果是粗糙荡灾,扭曲瓤狐,難以理解,混淆的命令式面向?qū)ο蟮拇a與一個(gè)很簡(jiǎn)潔的語(yǔ)法批幌。是的础锐,我們可以通過(guò)創(chuàng)建單獨(dú)的類和lambda來(lái)以更冗長(zhǎng)的方式編寫完全相同的狡猾代碼。

相反荧缘,即使用Java編寫實(shí)際的功能代碼皆警,我們也可以用簡(jiǎn)潔的lambdas編寫帶有詳細(xì)的類定義和對(duì)象的相同代碼。

懶惰和表現(xiàn)
在所有性能最佳的代碼未執(zhí)行代碼之后截粗,懶惰可以提高性能信姓。


Tip TCP的窗口滑動(dòng)

圖1.jpg
  • 窗口左邊沿向右邊沿靠近為窗口合攏。這種現(xiàn)象發(fā)生在數(shù)據(jù)被發(fā)送和確認(rèn)時(shí)绸罗。
  • 當(dāng)窗口右邊沿向右移動(dòng)時(shí)將允許發(fā)送更多的數(shù)據(jù)意推,我們稱之為窗口張開。這種現(xiàn)象發(fā)
    生在另一端的接收進(jìn)程讀取已經(jīng)確認(rèn)的數(shù)據(jù)并釋放了 T C P的接收緩存時(shí)珊蟀。
  • 當(dāng)右邊沿向左移動(dòng)時(shí)菊值,我們稱之為窗口收縮。 Host Requirements RFC強(qiáng)烈建議不要使

Share ConcurrentHashMap1.7實(shí)現(xiàn)

為什么要使用ConcurrentHashMap系洛?

  1. 多線程環(huán)境下俊性,HashMap會(huì)處于不安全狀態(tài)。例如put操作可能會(huì)引起程序死循環(huán)描扯,Cpu占有率達(dá)百分百定页,原因是多線程會(huì)導(dǎo)致HashMap的Entry鏈表形成環(huán)形數(shù)據(jù)結(jié)構(gòu),如此一來(lái)绽诚,他的next結(jié)點(diǎn)將永不為空典徊,就會(huì)產(chǎn)生死循環(huán)獲取Entry。既然不能使用HashMap恩够,在多線程環(huán)境下就給并發(fā)容器有了登場(chǎng)機(jī)會(huì)卒落。具體請(qǐng)參考談?wù)凥ashMap線程不安全的體現(xiàn) .
  2. Hashtable效率低下。Hashtable相信很多人都知道蜂桶,相比HashMap就增加了線程安全機(jī)制儡毕,在過(guò)去Hashtable就會(huì)被使用,但由于它的實(shí)現(xiàn)是利用synchronized來(lái)保證線程安全的,在線程競(jìng)爭(zhēng)激烈的情況下腰湾,效率就非常低下了雷恃。原因在于當(dāng)有線程訪問Hashtable的同步方法時(shí),其他線程也來(lái)訪問就會(huì)進(jìn)行阻塞或者輪詢狀態(tài)费坊。因此效率低下倒槐,如今開發(fā)中已經(jīng)鮮有人使用Hashtable了。
  3. ConcurrentHashMap采用鎖分段技術(shù)可有效提高并發(fā)訪問率附井。

參考文獻(xiàn):
《TCP-IP詳解》
Lambdas不是函數(shù)式編程
ConcurrentHashMap1.7實(shí)現(xiàn)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末讨越,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子永毅,更是在濱河造成了極大的恐慌把跨,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件卷雕,死亡現(xiàn)場(chǎng)離奇詭異节猿,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)漫雕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門滨嘱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人浸间,你說(shuō)我怎么就攤上這事太雨。” “怎么了魁蒜?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵囊扳,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我兜看,道長(zhǎng)锥咸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任细移,我火速辦了婚禮搏予,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘弧轧。我一直安慰自己雪侥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布精绎。 她就那樣靜靜地躺著速缨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪代乃。 梳的紋絲不亂的頭發(fā)上旬牲,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼引谜。 笑死牍陌,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的员咽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼贮预,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼贝室!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起仿吞,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤滑频,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后唤冈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體峡迷,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年你虹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了绘搞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡傅物,死狀恐怖夯辖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情董饰,我是刑警寧澤蒿褂,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站卒暂,受9級(jí)特大地震影響啄栓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜也祠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一昙楚、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧齿坷,春花似錦桂肌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至遂蛀,卻和暖如春谭跨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工螃宙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蛮瞄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓谆扎,卻偏偏與公主長(zhǎng)得像挂捅,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子堂湖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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

  • Java集合類可用于存儲(chǔ)數(shù)量不等的對(duì)象,并可以實(shí)現(xiàn)常用的數(shù)據(jù)結(jié)構(gòu)如棧,隊(duì)列等,Java集合還可以用于保存具有映射關(guān)...
    小徐andorid閱讀 1,946評(píng)論 0 13
  • 從三月份找實(shí)習(xí)到現(xiàn)在闲先,面了一些公司,掛了不少无蜂,但最終還是拿到小米伺糠、百度、阿里斥季、京東训桶、新浪、CVTE酣倾、樂視家的研發(fā)崗...
    時(shí)芥藍(lán)閱讀 42,275評(píng)論 11 349
  • 小編費(fèi)力收集:給你想要的面試集合 1.C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用舵揭。 當(dāng)JAVA程序違反了JA...
    八爺君閱讀 4,596評(píng)論 1 114
  • 九種基本數(shù)據(jù)類型的大小,以及他們的封裝類灶挟。(1)九種基本數(shù)據(jù)類型和封裝類 (2)自動(dòng)裝箱和自動(dòng)拆箱 什么是自動(dòng)裝箱...
    關(guān)瑋琳l(shuí)inSir閱讀 1,891評(píng)論 0 47
  • 小區(qū)門口的路修建好了琉朽。干凈,整潔稚铣,還有一個(gè)賞心悅目的綠化帶箱叁。 但是這個(gè)綠化帶不偏不倚的設(shè)在了拐角處,一個(gè)90度直角...
    安心做碼字農(nóng)民工_芒果Z閱讀 228評(píng)論 1 0