iOS 每日算法(Swift)

“不积跬步,无以至千里;不积小流,无以成江海”

算法的重要性我就不说了,不论是平时的项目中还是找工作的面试过程中,算法都是必不可少的,同时算法可以锻炼我们的思维逻辑能力以及解决问题的能力。
今天开始我就会从各类书籍以及博客等挑选出优质的算法题与大家分享,从简到难,在练习算法的同时,我也会对算法中运用的知识点进行整理,与大家共同学习成长,只要我们每天抽出半个小时到一个小时的时间去学习、整理、以及反思,我相信一段时间过后你会成长很多。

目录

1. 给出一个整形数组和一个目标值,判断数组中是否有两个数之和等于目标值。
2. 利用递归算法求1到n的和
3. 不借用第三个变量,如何交换两个变量的值?(变量a,b)

1. 给出一个整形数组和一个目标值,判断数组中是否有两个数之和等于目标值。

法一:很多人可能搭眼一看就能想到每次选中一个数,然后遍历整个数组判断有没有一个数相加之和等于目标值。但是这种方法的时间复杂度为O(n²),太复杂,所以我们需要找到更好的方法优化时间复杂度。

法二:我们可以利用集合处理这次问题,在遍历数组的过程中,我们利用字典保存当前值,假如字典中存在一个数等于目标值减去当前值,那么可以证明整个遍历中一定有两个数之和等于目标值。你可以这种方法的时间复杂度为O(n)。

代码:

    func judgeTwoNums(numsArr: [Int], targetValue: Int) -> Bool {
        var set = Set<Int>()
        for num in numsArr {
            if set.contains(targetValue - num) {
               return true
            }
            set.insert(num)
            print("有两个数之和等于目标值")
        }
        return false
    }

拓展:

给定一个整形数组中有且仅有两个数之和等于目标值,求这两个数在数组中的序号。

此题的思路跟上面题的思路基本相似,不同之处是此题需要得到两个数在数组中的序号,所以不能使用集合(排列无序)来解决这个问题,为了方便得到序列号,我们使用字典来解决这个问题。时间的复杂度为O(n)。

    func judgeTwoNum(numsArr: [Int], targetValue: Int) -> [Int] {
        var dict = [Int: Int]()
        for (i, num) in numsArr.enumerated() {
            if let index = dict[targetValue - num] {
                return [index, i]
            } else {
                dict[num] = i
            }
        }
        return []
    }

知识点:

集合(set):用来存储没有固定顺序、类型相同且不重复的值。

2. 利用递归算法求1到n的和

所谓递归,简单点来说,就是一个函数直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解。

    //    MARK: 递归算法
    func sum(n: Int) -> Int {
        var result: Int
        if n == 0 {
            return 0
        } else if n == 1 {
            return 1
        } else {
            result = sum(n: (n - 1)) + n
            return result
        }
    }

3. 不借用第三个变量,如何交换两个变量的值?(变量a,b)

法一:

a = a + b
b = a- b --> b = (a + b) - b --> b = a
a= a- b --> a = (a + b) - b(此时b=a) --> a = b
a = a - b
b = a + b --> (a - b) + b --> b = a
a = a + b --> (a - b) + b(此时b=a) --> a= b

法二(按位异或):
参加运算的两个数,换算为二进制(0、1)后,进行异或运算。只有当相应位上的数字不相同时,该为才取1,若相同,即为0。任何数与0异或,结果都是其本身。

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