LeetCode筆記:350. Intersection of Two Arrays II

問題:

Given two arrays, write a function to compute their intersection.
Example:
Given nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2, 2].
Note:
Each element in the result should appear as many times as it shows in both arrays.
The result can be in any order.
Follow up:
What if the given array is already sorted? How would you optimize your algorithm?
What if nums1's size is small compared to nums2's size? Which algorithm is better?
What if elements of nums2 are stored on disk, and the memory is limited such that you cannot load all elements into the memory at once?

大意:

給出兩個(gè)數(shù)組编振,寫一個(gè)函數(shù)來計(jì)算他們的交叉點(diǎn)。
例子:
給出數(shù)組 nums1 = [1,2,2,1],nums2 = [2,2],返回[2,2]。
注意:
在結(jié)果中每個(gè)元素出現(xiàn)的次數(shù)應(yīng)該與他們在兩個(gè)數(shù)組中出現(xiàn)的次數(shù)一樣遗遵。
結(jié)果可以是亂序的。
進(jìn)階:
如果給出的數(shù)組已經(jīng)是排好序的呢?你會(huì)如何優(yōu)化你的算法臼膏?
如果nums1的尺寸比nums2要小呢?哪個(gè)算法更好示损?
如果nums2中的元素是存儲(chǔ)在硬盤上的渗磅,而由于內(nèi)存是有限的你不能一次把所有元素都加載到內(nèi)存中,怎么辦?

思路:

這個(gè)問題是之前一個(gè)問題的簡單變形:傳送門:LeetCode筆記:349. Intersection of Two Arrays始鱼。這個(gè)題目的變化在于他不要求每個(gè)數(shù)字只出現(xiàn)一次了仔掸,而是要求交叉了幾次就保留幾次,這其實(shí)更簡單医清,還是之前題目的解法起暮,把保障數(shù)字唯一性的代碼去掉就好了,速度依然很快会烙,3ms负懦。
對于它提出來的三個(gè)問題,解答如下:

  • 如果數(shù)組已經(jīng)排好序了柏腻,更簡單纸厉,把排序過程都省掉。
  • 如果nums1尺寸更小五嫂,這其實(shí)對于我的解法不影響颗品,反正哪個(gè)數(shù)組先遍歷完都會(huì)結(jié)束循環(huán)。
  • 如果nums2的元素不能一次讀取沃缘,那就一個(gè)個(gè)讀取然后在nums1中尋找相同的數(shù)字躯枢,只是如果找到了記得要在nums1中去掉該位置的數(shù)字,等把nums2比較完了或者nums1被減沒了就結(jié)束了孩灯。

代碼(Java):

public class Solution {
    public int[] intersect(int[] nums1, int[] nums2) {
        int results[] = new int[nums1.length];// 結(jié)果數(shù)組
        
        // 沒有數(shù)字的情況
        if (nums1.length == 0 || nums2.length == 0) {
            return new int[0];
        }
        
        // 先對兩個(gè)數(shù)組排序
        Arrays.sort(nums1);
        Arrays.sort(nums2);
        
        int index = 0;
        for (int i = 0, j = 0; i < nums1.length; ) {
            if (nums1[i] < nums2[j]) {// 第一個(gè)數(shù)組中數(shù)字小
                i++;
            } else if (nums1[i] == nums2[j]) {// 數(shù)字相同闺金,放入結(jié)果數(shù)組
                results[index] = nums1[i];
                index++;
                i++;
                // 判斷第二個(gè)數(shù)組有沒有到最后一個(gè)數(shù)組,還沒到才繼續(xù)往后移去比
                if (j < nums2.length-1) j++;
                else break;
            } else {// 第二個(gè)數(shù)組中數(shù)字小峰档,注意要判斷是否到達(dá)最后一個(gè)數(shù)字
                if (j < nums2.length-1) j++;
                else break;
            }
        }
        
        return Arrays.copyOfRange(results, 0, index);// 結(jié)果數(shù)組只返回有數(shù)字的那一部分
    }
}

合集:https://github.com/Cloudox/LeetCode-Record


查看作者首頁

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末败匹,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子讥巡,更是在濱河造成了極大的恐慌掀亩,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件欢顷,死亡現(xiàn)場離奇詭異槽棍,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)抬驴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門炼七,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人布持,你說我怎么就攤上這事豌拙。” “怎么了题暖?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵按傅,是天一觀的道長捉超。 經(jīng)常有香客問我,道長唯绍,這世上最難降的妖魔是什么拼岳? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮况芒,結(jié)果婚禮上惜纸,老公的妹妹穿的比我還像新娘。我一直安慰自己牛柒,他們只是感情好堪簿,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著皮壁,像睡著了一般椭更。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蛾魄,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天虑瀑,我揣著相機(jī)與錄音,去河邊找鬼滴须。 笑死舌狗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的扔水。 我是一名探鬼主播痛侍,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼魔市!你這毒婦竟也來了主届?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤待德,失蹤者是張志新(化名)和其女友劉穎君丁,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體将宪,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绘闷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了较坛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片印蔗。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖丑勤,靈堂內(nèi)的尸體忽然破棺而出喻鳄,到底是詐尸還是另有隱情,我是刑警寧澤确封,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布除呵,位于F島的核電站,受9級(jí)特大地震影響爪喘,放射性物質(zhì)發(fā)生泄漏颜曾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一秉剑、第九天 我趴在偏房一處隱蔽的房頂上張望泛豪。 院中可真熱鬧,春花似錦侦鹏、人聲如沸诡曙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽价卤。三九已至,卻和暖如春渊涝,著一層夾襖步出監(jiān)牢的瞬間慎璧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工跨释, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留胸私,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓鳖谈,卻偏偏與公主長得像岁疼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子缆娃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

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