小马的力扣日记Day3 数组 #209 长度最小的子数组

#209 长度最小的子数组

题目

思路

这个题拿到之后首先考虑了两种思路。

第一种思路:从前往后遍历数组每一个数,从该数开始往后一直加,直到和大于等于target,就记录下该子串的长度,如果小于之前其他子串的长度,就用这个长度覆盖掉最小子数组长度,然后记录下该下标Index。这样的做法需要遍历每一个数,且最坏情况下,每一次都需要遍历到最后一个数才有结果,所以时间复杂度o(n^2)

第二种思路,既然题目是要找最小长度的子串长度,那就让子串长度从0出发,去验证是否存在这样长度的子串。由于是从小到大进行判断,那么一旦检测到存在该长度的子串,那就可以直接结束循环了,此时已经找到题目要求的数组和长度了。虽然相较于第一种思路而言得到了优化,但是算法的时间复杂度仍然是o(n^2)


代码

class Solution {

public:

    int minSubArrayLen(int target, vector<int>& nums) {

        int time,i,j,count=0;

        int sum[nums.size()];

        sum[0]=nums[0];


        for (i=1 ; i<nums.size();i++)

        {

          sum[i]=sum[i-1]+nums[i];     

        }

        for (time=1; time<nums.size()+1; time++)

        {

            for (i=0 ; i<(nums.size()-time+1); i++)

            {

                if (i==0)

                {

                    count=sum[time+i-1];

                }

                else {

                    count=sum[time+i-1]-sum[i-1];

                }       

                if (count>=target)

                {

                    return time;

                }

                count=0;

            }

        }

        return 0;

    }

};


反思

用的暴力版滑动窗口,结果非常丑陋,原先没优化的时候时间复杂度是o(n^3),过不了最后两组数据量特别大的样例。我发现同一个窗口内有大量重复计算, 比如窗口大小为2的时候 要算num[0]+num[1], 到窗口大小为3的时候 要算num[0]+num[1]+num[2], 实际上这个num[0]+num[1]就一直在重复算。后来我先开了一个新数组sum,用来记录每个元素到第一个元素之间所有值的和sum[i],这样num[1]+num[2]就可以表示为sum[3]-sum[0],num[2]+num[3]+num[4]=sum[4]-sum[1],这个地方就优化为了o(n^2)。(不过还是好垃圾啊)

当然可以用双指针来做,我的思路是延续上面的sum数组,设置头尾两个指针,只要两者之间的差值大于target,就决定移动指针。如果头部指针+1带来的差值变化更小,就动头部指针。反之如果尾部指针-1带来的差值更小,就动尾部指针。直到两个指针之间距离小于等于target,那就找到了最小子串。(出了BUG 还在调试)

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