LeetCode.1128-等價多米諾骨牌對的數(shù)量(Number of Equivalent Domino Pairs)

這是小川的第394次更新香伴,第428篇原創(chuàng)

01 看題和準(zhǔn)備

今天介紹的是LeetCode算法題中Easy級別的第259題(順位題號是1128)妻率。給定多米諾骨牌列表,當(dāng)且僅當(dāng)(a == cb == d)或(a == db == c),dominoes[i] = [a,b]等價于dominoes[j] = [c,d]指蚜,也就是說,一個多米諾骨牌可以旋轉(zhuǎn)到等價于另一個多米諾骨牌涨椒。

返回0 <= i < j < dominoes.length摊鸡,并且dominoes[i]等價于dominoes[j](i,j)對數(shù)蚕冬。

例如:

輸入:dominoes = [[1,2],[2,1],[3,4],[5,6]]
輸出:1

注意

  • 1 <= dominoes.length <= 40000

  • 1 <= dominoes[i][j] <= 9

02 第一種解法

暴力解法免猾,直接使用兩層循環(huán),會超時囤热。

public int numEquivDominoPairs(int[][] dominoes) {
    int count = 0;
    for (int i=0; i<dominoes.length; i++) {
        for (int j=i+1; j<dominoes.length; j++) {
            int a = dominoes[i][0], b = dominoes[i][1];
            int c = dominoes[j][0], d = dominoes[j][1];
            if ((a == c && b == d) || (a == d && b == c)) {
                count++;
            }
        }
    }
    return count;    
}


03 第二種解法

題目的意思是找可以配對的數(shù)組猎提,也就是元素值相等的數(shù)組,為了降低時間復(fù)雜度旁蔼,就必須將二維數(shù)組降為一維數(shù)組锨苏。

既然是值相等,那可不可以用加法或者乘法棺聊?

不行伞租,因為加法或乘法不能保證唯一性。比如[1,6]和[2,3]限佩,做乘法后都等于6葵诈,但是這兩數(shù)組明顯不配對。

那我們把它變成一個兩位數(shù)祟同,較小的一個當(dāng)做十位數(shù)作喘,較大的當(dāng)做個位數(shù),這樣一轉(zhuǎn)換后耐亏,二維數(shù)組就變成了一維數(shù)組徊都,此時題目也就變成了計數(shù)的問題。

因為數(shù)組元素的取值范圍是[1,9]广辰,所以最大的兩位數(shù)是99暇矫,最小的兩位數(shù)是11,使用一個長度為100的整型數(shù)組即可择吊。

最后遍歷計數(shù)數(shù)組中的元素李根,計算對數(shù),其實就是計算排列組合几睛,有n個數(shù)房轿,分兩次取,總共有n*(n-1)種可能,但是需要去重囱持,因為i要小于j夯接,所以最后就是n*(n-1)/2種可能,將每次的結(jié)果累加纷妆,最后返回即可盔几。

public int numEquivDominoPairs2(int[][] dominoes) {
    int[] count = new int[100];
    for (int[] temp : dominoes) {
        int num = Math.min(temp[0], temp[1])*10
                + Math.max(temp[0], temp[1]);
        count[num]++;
    }
    int result = 0;
    for (int num : count) {
        result += num*(num-1)/2;
    }
    return result;
}


04 第三種解法

和第二種解法一樣的處理邏輯,只是將計數(shù)數(shù)組換成HashMap來處理掩幢。

public int numEquivDominoPairs3(int[][] dominoes) {
    Map<Integer, Integer> map = new HashMap<Integer,Integer>();
    for (int[] temp : dominoes) {
        int num = Math.min(temp[0], temp[1])*10
                + Math.max(temp[0], temp[1]);
        map.put(num, map.getOrDefault(num, 0)+1);
    }
    int result = 0;
    for (Integer times : map.values()) {
        result += times*(times-1)/2;
    }
    return result;
}


05 第四種解法

此解法同樣利用HashMap逊拍,但是HashMapkey是字符串,先轉(zhuǎn)為一個兩位數(shù)际邻,然后再轉(zhuǎn)成字符串芯丧。另外,計算配對的對數(shù)也有一點不同世曾,是用累加來算的缨恒,不算最后的n,只從1算到n-1度硝,效果和前面用排列組合的一樣肿轨。

public int numEquivDominoPairs4(int[][] dominoes) {
    Map<String, Integer> map = new HashMap<String,Integer>();
    int count = 0;
    for (int[] temp : dominoes) {
        StringBuilder sb = new StringBuilder();
        sb.append(""+Math.min(temp[0], temp[1])
                + Math.max(temp[0], temp[1]));
        String str = sb.toString();
        if (map.containsKey(str)) {
            count += map.get(str);
        }
        map.put(str, map.getOrDefault(str, 0)+1);
    }
    return count;
}


06 小結(jié)

算法專題目前已連續(xù)日更超過八個月,算法題文章265+篇蕊程,公眾號對話框回復(fù)【數(shù)據(jù)結(jié)構(gòu)與算法】椒袍、【算法】、【數(shù)據(jù)結(jié)構(gòu)】中的任一關(guān)鍵詞藻茂,獲取系列文章合集驹暑。

以上就是全部內(nèi)容,如果大家有什么好的解法思路辨赐、建議或者其他問題优俘,可以下方留言交流,在看掀序、留言帆焕、轉(zhuǎn)發(fā)就是對我最大的回報和支持!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末不恭,一起剝皮案震驚了整個濱河市叶雹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌换吧,老刑警劉巖折晦,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異沾瓦,居然都是意外死亡满着,警方通過查閱死者的電腦和手機(jī)谦炒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來风喇,“玉大人宁改,你說我怎么就攤上這事∠炻浚” “怎么了透且?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長豁鲤。 經(jīng)常有香客問我,道長鲸沮,這世上最難降的妖魔是什么琳骡? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮讼溺,結(jié)果婚禮上楣号,老公的妹妹穿的比我還像新娘。我一直安慰自己怒坯,他們只是感情好炫狱,可當(dāng)我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著剔猿,像睡著了一般视译。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上归敬,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天酷含,我揣著相機(jī)與錄音,去河邊找鬼汪茧。 笑死椅亚,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的舱污。 我是一名探鬼主播呀舔,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼扩灯!你這毒婦竟也來了媚赖?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤驴剔,失蹤者是張志新(化名)和其女友劉穎省古,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體丧失,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡豺妓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片琳拭。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡训堆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出白嘁,到底是詐尸還是另有隱情坑鱼,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布絮缅,位于F島的核電站鲁沥,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏耕魄。R本人自食惡果不足惜画恰,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吸奴。 院中可真熱鬧允扇,春花似錦、人聲如沸则奥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽读处。三九已至糊治,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間档泽,已是汗流浹背俊戳。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留馆匿,地道東北人抑胎。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像渐北,于是被迫代替她去往敵國和親阿逃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,871評論 2 354

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

  • 在C語言中,五種基本數(shù)據(jù)類型存儲空間長度的排列順序是: A)char B)char=int<=float C)ch...
    夏天再來閱讀 3,342評論 0 2
  • 計算機(jī)二級C語言上機(jī)題庫(南開版) 1.m個人的成績存放在score數(shù)組中赃蛛,請編寫函數(shù)fun,它的功能是:將低于平...
    MrSunbeam閱讀 6,366評論 1 42
  • 貪心算法 貪心算法總是作出在當(dāng)前看來最好的選擇恃锉。也就是說貪心算法并不從整體最優(yōu)考慮,它所作出的選擇只是在某種意義上...
    fredal閱讀 9,231評論 3 52
  • 周日突然興致大發(fā)在她旁邊玩弄起吉他呕臂。 這個多年被我拋在旁邊從不問津的吉他破托。 她說從來沒見我彈吉他,心想那我這次就談...
    Ermao閱讀 286評論 0 1
  • 蔓抱葡萄夏初楊歧蒋, 小荷才露水中央土砂。 柳堤馬踏寒煙翠州既, 哪里曾是故人莊。
    果然全身閱讀 284評論 16 28