349 intersection of two arrays

Given two arrays, write a function to compute their intersection.

Example:
Given nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2].

Note:

    Each element in the result must be unique.
    The result can be in any order.



#define HASH_SIZE 100
//hash arrary + linked list
struct listnode{
    int val;
    int found;
    struct listnode *next;
};

int hash_func(int value)
{
    return abs(value)%HASH_SIZE;
}


int* intersection(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize) {

    struct listnode ** hash = calloc(HASH_SIZE, sizeof(struct listnode*));
    int index ;
    int * array = calloc(nums1Size<nums2Size?nums1Size:nums2Size, sizeof(int));
    int count = 0;
    struct listnode * dummyhead;
    for(int i = 0 ; i < HASH_SIZE; i++){
        hash[i] = malloc(sizeof(struct listnode));
        hash[i]->next = NULL;
    }
    int duplicate = 0;
    for(int i = 0 ; i < nums1Size; i++){
        index  = hash_func(nums1[i]);
        dummyhead = hash[index];
        struct listnode * node = malloc(sizeof(struct listnode));
        node->val = nums1[i];
        node->next = NULL;
        node->found = 0;
        while(dummyhead->next!=NULL){
              if(dummyhead->next->val == nums1[i]){
                    duplicate=1;
                    break;
                    
              }
              dummyhead = dummyhead->next;
        }
        if(duplicate){
            free(node);
            duplicate = 0;
        }else
            dummyhead->next = node;

    }

    for(int i = 0 ; i < nums2Size; i++){
        index  = hash_func(nums2[i]);
        dummyhead = hash[index];

        while(dummyhead->next!=NULL){
              if(dummyhead->next->val == nums2[i] && dummyhead->next->found == 0){
                    
                    array[count++] = nums2[i];
                    dummyhead->next->found = 1 ;
              }
              dummyhead = dummyhead->next;
        }
    }

    *returnSize = count;

    return array;
    
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖绍豁,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡做瞪,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門右冻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來装蓬,“玉大人,你說我怎么就攤上這事纱扭‰怪悖” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵乳蛾,是天一觀的道長暗赶。 經(jīng)常有香客問我鄙币,道長,這世上最難降的妖魔是什么蹂随? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任十嘿,我火速辦了婚禮,結(jié)果婚禮上岳锁,老公的妹妹穿的比我還像新娘绩衷。我一直安慰自己,他們只是感情好激率,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布咳燕。 她就那樣靜靜地躺著,像睡著了一般乒躺。 火紅的嫁衣襯著肌膚如雪招盲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天嘉冒,我揣著相機與錄音曹货,去河邊找鬼。 笑死讳推,一個胖子當著我的面吹牛控乾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播娜遵,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼蜕衡,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了设拟?” 一聲冷哼從身側(cè)響起慨仿,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎纳胧,沒想到半個月后镰吆,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡跑慕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年万皿,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片核行。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡牢硅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出芝雪,到底是詐尸還是另有隱情减余,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布惩系,位于F島的核電站位岔,受9級特大地震影響如筛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜抒抬,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一杨刨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧擦剑,春花似錦妖胀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽浇借。三九已至捉撮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間妇垢,已是汗流浹背巾遭。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留闯估,地道東北人灼舍。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像涨薪,于是被迫代替她去往敵國和親骑素。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

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