《算法图解》- Part1(算法简介)

一、算法简介

1.1 算法是
  • 算法是一组完成任务的指令。任何代码片段都可视为算法。
  • 通过查电话问题了解算法
    1. 问题:按字母排序的电话本(有 n 个电话号码),从中查找出以 k 开头的某个电话。
    2. 问题对应的常用算法有:
    简单查找,按顺序一个接一个查,最多需要的步骤是n步;
    二分查找,每次过滤一半的值,最多需要的步骤是logn

log 表示为以2为底的对数;

1.2 二分查找法 (查找列表必须为有序列表,默认递增类型)
/**
 二分查找(常见逻辑)

 @param sourceArray 源有序排列数数组
 @param searchingNum 要查找的数
 @return 要查找的数所在数组的位置索引,没有则返回-1
 */
+ (NSInteger)binarySearchWithoutRecursion:(NSArray *)sourceArray withSearchingNum:(NSNumber *)searchingNum {
    
    NSInteger low = 0;
    NSInteger high = sourceArray.count - 1;
    
    while (low <= high) {
        
        NSInteger middle = low + (high+low)/2;
        
        if (searchingNum.integerValue == [sourceArray[middle] integerValue]) {
            
            return middle;
            
        } else if(searchingNum.integerValue < [sourceArray[middle] integerValue]) {
            
            high = middle - 1;
            
        } else {
            
            low = middle + 1;
        }
    }
    return -1;
}


/**
 二分查找(使用递归方法)
 */
+ (NSInteger)binarySearchWithRecursion:(NSArray *)sourceArray withSearchingNum:(NSNumber *)searchingNum {
    
    NSInteger low = 0;
    NSInteger high = sourceArray.count - 1;
    
    return [self binSearch:sourceArray withLow:low withHigh:high withKeyNum:searchingNum];
}

+ (NSInteger)binSearch:(NSArray *)srcArray withLow:(NSInteger)low withHigh:(NSInteger)high withKeyNum:(NSNumber *)keyNum {
    
    if (low <= high) {
        
        NSInteger mid = (low + high)/2;
        
        if (keyNum.integerValue == [srcArray[mid] integerValue]) {
            
            return mid;
            
        } else if([keyNum integerValue] < [srcArray[mid] integerValue]) {
            
            return [self binSearch:srcArray withLow:low withHigh:(mid - 1) withKeyNum:keyNum];
            
        } else {
            
             return [self binSearch:srcArray withLow:mid+1 withHigh:high withKeyNum:keyNum];
        }
        
    } else {
        
        return -1;
    }
}

1.3 运行时间

说到算法时,都要讨论其运行时间,针对不同的算法,我们的选中目的通常是:

选择效率最高的算法,以最大限度的减少运行时间或占用的空间

如下图对应着简单查找二分查找 的运时间:

简单查找 和 二分查找 的运时间对比
1.4 大 O 表示法
1.4.1 大 O 表示法格式如下:
大 O 表示法格式.png
  • 大 O 表示法指出了算法有多快。
  • 大 O 表示法指定并非是以秒为单位的速度。
  • 大 O 表示法让你能够比较操作数,它指出了算法运行时间的增速
1.4.2 从算法角度看大 O 表示法:
  • 算法运行时间用大 O 表示法表示。
  • 算法运行时间并不以秒为单位。
  • 算法运行时间是从其增速的角度度量的。
1.4.3 大 O 表示法指出了最糟糕情况下的运行时间

假设要使用简单查找算法在电话簿中找人,而简单查找的运行时间为 O(n),这意味着在最糟糕的情况下,必须查看电话簿中的每个条目。如果要查找的是 Adit ——电话簿中的第一人,一次就能找到,无需查看每个条目。这种情况下这中算法的运行时间依然是 O(n),因为大 O 表示法不是用来表示最佳情形的,而是最糟糕情形。

1.4.4 一些常见的大 O 运行时间
  • O(log n),也叫对数时间(如:二分查找)。
  • O(n),也叫线性时间(如:简单查找)。
  • O(n * log n)。
  • O(n平方) 。
  • O(n!),著名的商旅问题使用的算法其运行时间就是这个。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容