iOS開發(fā)進階-算法二

課程: 新浪微博資深大牛全方位剖析 iOS 高級面試

一苍姜、哈希算法

在一個字符串中找到第一個只出現(xiàn)一次的字符译蒂。例如:輸入“abaccdeff”輸出b曼月。

思路:考察hash的使用,利用每個字母的ASCII碼作hash來作為數組的index柔昼。使用一個數組存儲每個字母出現(xiàn)的次數哑芹,數組記錄的內容是該字母出現(xiàn)的次數,最終遍歷字符串捕透,找到第一個數組內容為1的字母即可聪姿。時間復雜度為O(n)。

char findFirstChar(char *cha) {
    char result = '\0';
    // 用于存放每個字符出現(xiàn)的次數乙嘀,下標為字符的ASCII值
    int array[256] = {0};
    char *p = cha;
    // 遍歷字符串末购,根據ASCII值存入數組中
    while (*p != '\0') {
        // 字符對應的存儲位置,進行次數+1操作虎谢。
        array[*(p++)]++;
    }
    //重置p指針
    p = cha;
    while (*p != '\0') {
        // 遇到第一個出現(xiàn)次數為1的字符盟榴,打印出結果。
        if (array[*p] == 1) {
            result = *p;
            break;
        }
        p++;
    }
    return result;
}

測試代碼:

void hash_findFirstCharTest() {
    char *cha = "gabaccdeff";
    char fc = findFirstChar(cha);
    printf("this char is %c \n", fc);
}

輸出結果:
this char is g

二婴噩、 查找兩個子視圖的共同父視圖

思路:記錄視圖A的所有父視圖存放到數組A擎场。將視圖B的所有父視圖存放到數組B。然后倒序比較兩個數組中的視圖几莽,當比較到第一個不一樣時迅办,之前找到的就是所有共同父視圖。

示例代碼:

- (NSArray<NSView *> *)findCommonSuperView:(NSView *)view other:(NSView *)viewOther {
    // 結果數組
    NSMutableArray *result = [NSMutableArray array];
    // 兩個子視圖所有父視圖組成的數組章蚣。
    NSArray *aSuperViews = [self findSuperView:view];
    NSArray *bSuperViews = [self findSuperView:viewOther];
    int i = 0;
    // 越界條件選取小的那個
    while (i < MIN(aSuperViews.count, bSuperViews.count)) {
        NSView *aSuperView = [aSuperViews objectAtIndex:aSuperViews.count - i - 1];
        NSView *bSuperView = [bSuperViews objectAtIndex:bSuperViews.count - i - 1];
        // 比較是否相等站欺,相等則為共同父視圖。不相等結束遍歷纤垂。
        if (aSuperView == bSuperView) {
            [result addObject:aSuperView];
            i++;
        } else {
            break;
        }
    }
    return result;
}
- (NSArray <NSView *> *)findSuperView:(NSView *)view {
    // 第一個父視圖
    NSView *temp = view.superview;
    NSMutableArray *result = [NSMutableArray array];
    while (temp) {
        [result addObject:temp];
        temp = temp.superview;
    }
    return result;
}

注意引入的是AppKit所以視圖為NSView矾策。

三、無序數組中的中位數洒忧。

方案:排序算法 + 中位數蝴韭;利用快排思路(分治思想)。
關于排序算法這里不再贅述熙侍,可以網上搜索榄鉴。
中位數:當n為奇數時履磨,(n + 1)/2 ;當n為偶數時,(n / 2 + (n / 2 + 1)/ 2庆尘。

思路:快排思想剃诅。任意選擇一個元素,以該元素為支點劃分數組為兩部分驶忌,如果左側集合長度恰好為(n -1)/2矛辕,那么支點就是中位數。如果左側長度小于(n - 1)/2付魔,那么中位數在右側聊品,否則中位數在左側。

示例代碼:

// 無序數組的中位數
int findMedian(int a[], int aLen) {
    
    int low = 0;
    int high = aLen - 1;
    
    // 中位下標
    int mid = (aLen - 1) / 2;
    // 第一遍快排
    int div = PartSort(a, low, high);
    
    while (div != mid) {
        if (mid < div) {
            // 左半區(qū)間
            div = PartSort(a, low, div - 1); // 遞歸
        } else {
            //右半區(qū)間
            div = PartSort(a, div + 1, high); // 遞歸
        }
    }
    return a[mid];
}

int PartSort(int a[], int start, int end) {
    // 兩個哨兵
    int low = start;
    int high = end;
    // 關鍵數
    int key = a[end];
    while (low < high) {
        // 左邊的值要比Key小
        while (low < high && a[low] <= key) {
            ++low;
        }
        // 右邊的值要比Key大
        while (low < high && a[high] >= key) {
            --high;
        }
        // 交換兩個哨兵對應的值
        if (low < high) {
            int temp = a[low];
            a[low] = a[high];
            a[high] = temp;
        }
    }
    // 交換關鍵數
    int temp = a[high];
    a[high] = a[end];
    a[end] = temp;
    return low;
}

測試代碼:

void findMedianTest() {
    int list[9] = {12,3,10,8,6,7,11,13,9};
    // 3 6 7 8 9 10 11 12 13
    //         ^
    int median = findMedian(list, 9);
    printf("the median is %d \n", median);
}

輸出結果:
the median is 9

小結

示例代碼倉庫地址:Algorithm

算法篇暫時告一段落几苍,以上只是幾個基本的算法題翻屈,僅僅是九牛一毛。推薦兩個網站:leetCode牌薨樱客網

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末伸眶,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子刽宪,更是在濱河造成了極大的恐慌厘贼,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件圣拄,死亡現(xiàn)場離奇詭異嘴秸,居然都是意外死亡,警方通過查閱死者的電腦和手機售担,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門赁遗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人族铆,你說我怎么就攤上這事】蕹ⅲ” “怎么了哥攘?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長材鹦。 經常有香客問我逝淹,道長,這世上最難降的妖魔是什么桶唐? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任栅葡,我火速辦了婚禮,結果婚禮上尤泽,老公的妹妹穿的比我還像新娘欣簇。我一直安慰自己规脸,他們只是感情好,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布熊咽。 她就那樣靜靜地躺著莫鸭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪横殴。 梳的紋絲不亂的頭發(fā)上被因,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音衫仑,去河邊找鬼梨与。 笑死,一個胖子當著我的面吹牛文狱,可吹牛的內容都是我干的蛋欣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼如贷,長吁一口氣:“原來是場噩夢啊……” “哼陷虎!你這毒婦竟也來了?” 一聲冷哼從身側響起杠袱,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤尚猿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后楣富,有當地人在樹林里發(fā)現(xiàn)了一具尸體凿掂,經...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年纹蝴,在試婚紗的時候發(fā)現(xiàn)自己被綠了庄萎。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡塘安,死狀恐怖糠涛,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情兼犯,我是刑警寧澤忍捡,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站切黔,受9級特大地震影響砸脊,放射性物質發(fā)生泄漏。R本人自食惡果不足惜纬霞,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一凌埂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧诗芜,春花似錦瞳抓、人聲如沸埃疫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽熔恢。三九已至,卻和暖如春臭笆,著一層夾襖步出監(jiān)牢的瞬間叙淌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工愁铺, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留鹰霍,地道東北人。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓茵乱,卻偏偏與公主長得像茂洒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子瓶竭,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內容