IOS 算法(中级篇) ----- 获取长度最小子数组

昨天做了个获取数组长度的题很有意思
如果你想知道什么题? 既然你诚心诚意的发问了, 我就大发慈悲的告诉你!

给定一个正整数的数组, 给定个正整数, 求正整数数组, 找出最小的连续数组使得相加之和>=给定的正整数, 没有返回0

例如 arr = [2, 3, 1, 2, 4, 3] , s = 7, 返回 [4, 3]

双循环
双循环, 暴力法是一个比较好理解的方法, 适合新手

  1. 数组如果包含给定值 s, 直接弹出
  2. 创建个初始的最小值
  3. 第一层循环: 依次循环初始位 sum[i]
  4. 第二层循环: i 之后的数字sum[j], 循环并相加, >= 给定值 s 时候判断 j-i+1 是否小于最小值min,
  5. 如果小, min为 j-i+1, 否则 min还是之前值
  6. 循环之后返回最小值

这里有几个点要注意一下
① 循环第二层j时, 如果找到>= s的时候,直接break, 减少不必要循环,
为什么呢? 因为再加已经没有意义, 我们找到的是 "长度最小的连续子数组", 而不是循环到底, 减少一定时间复杂度
② 留意初始设置的最小值min一定要"大"
③ 针对特殊情况, 数组包含s 特殊处理

swift

    func minSubArrayLen(_ s: Int, _ nums: [Int]) -> Int {
        // 如果数组包含s, 直接返回1, 包含最小长度即为1 
        if nums.contains(s) {
            return 1
        }
        // 设置初始值min, 最小值要大于数组长度, 我这里设置最小值为: 数组长度+1 
        // 小于的话会影响for下面判断, 不好处理
        // 等于的话要单独处理 数组之和全加完 >= s 情况
        var min = nums.count + 1

        // 开始循环数组
        for i in 0..<nums.count {
            // 设置初始和 sum 值为0
            var sum = 0
            for j in i..<nums.count {
                // 第二层循环, 依次累加
                sum = sum + nums[j]
                // 判断如果和大于等于s了, 弹出第二层循环, 再加也没有意义
                if(sum >= s){
                    //三目运算符 赋值min
                    min = (j-i+1)<min ? (j-i+1):min
                    break;
                }
            }
        }
        // 返回min, 如果min为初始值返回0
        return min==nums.count+1 ? 0:min;
    }

可看到, 这种方法节省空间复杂度, 但是在时间复杂度上却很耗, 由于双循环会使得时间复杂为O(n^2)
我更建议针对数据量小, 对内存消耗要求要低的情况下使用

双指针

双指针方法即: 定义两个指针, 循环开始位start, 循环结束位置end
循环判断 start位, end位 之间的元素和,
如果小于给定值s, end向右移动一位
如果大于给定值s, start向右移动一位,
依次判断 end - start + 1 与 min 的最小值赋给新的min, 最后返回最小 min

swift

    func minSubArrayLen(_ s: Int, _ nums: [Int]) -> Int {
        // 如果数组包含指定元素直接返回1
        if nums.contains(s) {
            return 1
        }
        // 定义初始值low high sum
        var low = 0, high = 0, sum = 0
        // 定义初始值min 大于数组长度即可
        var min = nums.count + 1
        // 循环high指针
        while high < nums.count  {
            // 总和加最新 nums[high]
            sum += nums[high]
            // 循环low指针
            while sum >= s  {
                // 取 min 和 high-low+1 的最小值 赋给新的 min
                min = (high-low+1)<min ? (high-low+1):min
                // 总和去掉之前的 nums[low]
                sum = sum - nums[low]
                // low向右移一位
                low += 1
            }
            // high向右移一位
            high += 1
        }
        // 三目运算符返回最小值
        return min==(nums.count + 1) ? 0:min;
    }

题目来源:力扣(LeetCode) 感谢力扣爸爸 :)

IOS 算法合集地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念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