这是我参与11月更文挑战的第25天,活动详情查看:2021最后一次更文挑战。
描述
给定两个数组,编写一个函数来计算它们的交集。
1 | ini复制代码示例 1: |
说明:
- 输出结果中每个元素出现的次数,应与元素在两个数组中出现次数的最小值一致。
- 我们可以不考虑输出结果的顺序。
做题
这个说明的第一条我没太看懂。
从题目“两个数组的交集”上推测,应该是不需要考虑两个数组的顺序。
我一开始还以为,要考虑两个数组的顺序,像 试例 2 的 [4,9] 就有顺序,那样就比较难做了,唯一的做法可能就是两层遍历循环了。
因为不需要考虑结果的顺序,所以我们可以考虑使用 map 来存储每个数出现的个数,然后取相同的次数最少的数作为结果返回。
1 | java复制代码public int[] intersect(int[] nums1, int[] nums2) { |
跑是跑通了。
但是效率好低,代码也很长。
这部分代码优化一下,把它和第二循环结合到一起,降低时间复杂度。
1 | ini复制代码public int[] intersect1(int[] nums1, int[] nums2) { |
不优化不知道,一优化就减少了二十多行代码,还把 map2 优化掉了。
不过这个运行结果怎么内存占用还变高了?
今天就到这里了。
这里是程序员徐小白,【每日算法】是我新开的一个专栏,在这里主要记录我学习算法的日常,也希望我能够坚持每日学习算法,不知道这样的文章风格您是否喜欢,不要吝啬您免费的赞,您的点赞、收藏以及评论都是我下班后坚持更文的动力。
本文转载自: 掘金