LeetCode算法,每日一题,冲击阿里巴巴,day3_每个箱子上有一个数字,阿里巴巴念出一个数字k,找出连续k个宝箱数字和的最大值

(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。

进阶:

你能否实现线性时间复杂度、仅使用额外常数空间的算法解决此问题?

小编菜解
private static int test01(int[] nums){
    Arrays.sort(nums);

    if (nums[0] != 0){
        return 0;
    }

    if (nums[nums.length-1] != nums.length){
        return nums.length;
    }

    int min = 0;
    int max = nums.length;
    for (int i = 0; i < max; i++) {
        int next = nums[i]+1;
        if (i+1 <max && nums[i+1]!=next){
            return next;
        }
    }
    return -1;
}

2、LeetCode 283.移动零

题目

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

小编菜解
private static void test02(int[] nums){
    int[] temp = new int[nums.length];
    int zeroNum = 0;
    int notZeroNum = 0;
    for (int i = 0; i < nums.length; i++) {
        if (nums[i]!=0){
            temp[notZeroNum] = nums[i];
            notZeroNum++;
        }else{
            temp[nums.length - 1 - zeroNum] = 0;
            zeroNum++;
        }
    }
}
思路及算法

使用双指针,左指针指向当前已经处理好的序列的尾部,右指针指向待处理序列的头部。

右指针不断向右移动,每次右指针指向非零数,则将左右指针对应的数交换,同时左指针右移。

注意到以下性质:

左指针左边均为非零数;

右指针左边直到左指针处均为零。

因此每次交换,都是将左指针的零与右指针的非零数交换,且非零数的相对顺序并未改变。

大佬指点江山
public static void moveZeroes(int[] nums) {
    int n = nums.length, left = 0, right = 0;
    while (right < n){
        if (nums[right] != 0){
            swap(nums,left,right);
            left++;
        }
        right++;
    }
}

public static void swap(int[] nums, int left, int right) {
    int temp = nums[left];
    nums[left] = nums[right];
    nums[right] = temp;
}

大佬想的和我想的确实是不一样的。

3、LeetCode 290.单词规律

题目

给定一种规律 pattern 和一个字符串 str ,判断 str 是否遵循相同的规律。

这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着双向连接的对应规律。

小编菜解
public static  boolean wordPattern(String pattern, String s) {
    int pl = pattern.length();
    String[] arr = s.split(" ");
    int sl = arr.length;
    if (pl!=sl){
        return false;
    }
    Map<Character, String> map1 = new HashMap<Character, String>();
    Map<String, Character> map2 = new HashMap<String, Character>();
    for (int i = 0; i < pl; i++) {
        if (!map1.containsKey(pattern.charAt(i))){
            if (map2.containsKey(arr[i])){
                return false;
            }
            map1.put(pattern.charAt(i),arr[i]);
            map2.put(arr[i],pattern.charAt(i));
        }else{
            if(!map1.get(pattern.charAt(i)).equals(arr[i])){
                return false;
            }
        }
    }
    return true;
}
大佬指点江山
public boolean wordPattern(String pattern, String str) {
    Map<String, Character> str2ch = new HashMap<String, Character>();
    Map<Character, String> ch2str = new HashMap<Character, String>();
    int m = str.length();
    int i = 0;
    for (int p = 0; p < pattern.length(); ++p) {
        char ch = pattern.charAt(p);
        if (i >= m) {
            return false;
        }
        int j = i;
        while (j < m && str.charAt(j) != ' ') {
            j++;
        }
        String tmp = str.substring(i, j);
        if (str2ch.containsKey(tmp) && str2ch.get(tmp) != ch) {
            return false;
        }
        if (ch2str.containsKey(ch) && !tmp.equals(ch2str.get(ch))) {
            return false;
        }
        str2ch.put(tmp, ch);
        ch2str.put(ch, tmp);
        i = j + 1;
    }
    return i >= m;
}

如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、全套PDF电子书

书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

四、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值