美文网首页
3 ARTS打卡第三周(2019-08-19)

3 ARTS打卡第三周(2019-08-19)

作者: 无敌的潘大帅 | 来源:发表于2019-08-19 20:15 被阅读0次

Algorithm

本周LeetCode 题目:350. 两个数组的交集 II
题解思路:首先,将两个数组进行排序。比较两个数组的长度,将长度较小的那个放在外层循环,长度较长的放在内层循环,这样的做法是可以减少检索的次数,当数组长度相差极大的时候,这种方式的优点就可以凸显。随后,进行遍历获取交集,假设刚开始的前n次遍历没有找到相等的数字,则下次遍历还会从0索引开始。如果在前n次遍历中,在第n次遍历,找到相等项,处理之后结束内层循环,则第n+1次会在第n次的索引i+1 处的地方继续进行遍历,这样得益于排序之后的好处。
题解代码:

class Solution {
    public int[] intersect(int[] nums1, int[] nums2) {
        Arrays.sort(nums1);
        Arrays.sort(nums2);
        List<Integer> result = new ArrayList<>();
        int start = 0;
        if(nums1.length <= nums2.length) {
            for (int i = 0; i < nums1.length; i++) {
                int find = nums1[i];
                for (int j = start; j < nums2.length; j++) {
                    if (find == nums2[j]) {
                        result.add(Integer.valueOf(find));
                        start = j + 1;
                        break;
                    }

                }
            }
        } else {
            for (int i = 0; i < nums2.length; i++) {
                int find = nums2[i];
                for (int j = start; j < nums1.length; j++) {
                    if (find == nums1[j]) {
                        result.add(Integer.valueOf(find));
                        start = j + 1;
                        break;
                    }
                }
            }
        }

        int[] nums3 = new int[result.size()];
        for (int i = 0; i < result.size(); i++) {
            nums3[i] = result.get(i);
        }
        return nums3;
    }
    
}

Review

本周文章:Why you should totally switch to Kotlin
个人见解;我自己的主语言是Java,这篇文章表达了许多有关于Kotlin这门编程语言的好处,的确有挺多解决Java语言之前的痛点的(个人基于JDK 8来阐述),比如两个对象的数据都相等的话,我们在现实生活中就会认为这两个对象是相等的,而在Java的语法中,在默认的equals方法,因为这两个对象所存放的内存地址是不同的,所以就会返回false,所以会让Java程序员重写了equals方法,但是在Kotlin中提供了==和===比较符,==只要数据相同就会返回true,而===的结果同默认的equals方法。这样省去了重复性的编码,但是Kotlin虽然是简化Java的代码风格,但是个人感觉语法风格上还是有些别扭,给我的感觉是基于Java和Python中间,Python的语法是真的让我感觉很简洁明了。

Tip

本周Tip:在Java中,方法的调用永远是值调用,而不像C++,Python有引用调用及值调用(基于JDK 8)

Share

最近迷上了一部美剧叫Stranger Things,中文译名:怪奇物语,非常好看。可以用来学习英语。

相关文章

  • 3 ARTS打卡第三周(2019-08-19)

    Algorithm 本周LeetCode 题目:350. 两个数组的交集 II题解思路:首先,将两个数组进行排序。...

  • ARTS打卡第三周

    ARTS打卡第三周 Algorithm:每周至少做一个 leetcode 的算法题 839. 相似字符串组 解题思...

  • ARTS 打卡 3

    Algorithm 53. 最大子序和简单的解题思路是O(nlogn),使用一维数组记录index前面所有数的和,...

  • ARTS打卡,第三周

    每周完成一个ARTS:1.A(Algorithm)每周至少做一个 leetcode 的算法题2.R(Review)...

  • ARTS打卡第三周

    Algorithm Review 个人语音计算平台想让类airpods产品成为一个突破性的个人计算平台(就像sma...

  • ARTS打卡 第3周

    打卡日期 2019-07-29 至 2019-08-04Algorithm:58. 最后一个单词的长度https:...

  • 风云的ARTS打卡(第三周)

    第3周 Algorithm: 最长回文子串 给定一个字符串s,找到s中最长的回文子串。你可以假设s的最大长度为 1...

  • ARTS第三周

    Algorithm leetCode 60 Permutation SequenceGiven n and k, ...

  • 第三周ARTS

    Algorithmic 用链表将两数相加,之后输出和。https://leetcode-cn.com/proble...

  • ARTS第三周

    Algorithm。主要是为了编程训练和学习。每周至少做一个 leetcode 的算法题(先从Easy开始,然后再...

网友评论

      本文标题:3 ARTS打卡第三周(2019-08-19)

      本文链接:https://www.haomeiwen.com/subject/iveesctx.html