Lintcode——两数组的交 II
来源:互联网 发布:网络借贷平台哪个方便 编辑:程序博客网 时间:2024/05/16 18:30
1.题目
计算两个数组的交
注意事项
每个元素出现次数得和在数组里一样
答案可以以任意顺序给出
样例
nums1 = [1, 2, 2, 1]
, nums2 = [2, 2]
, 返回 [2, 2]
.
2.思路
首先对两个数组分别排序;
然后从头开始遍历比对两个数组(当1数组的i位小于2数组的j位时,可以直接下移比对1数组的i+1位和2数组的j位;2数组j位小于1数组的i位时则2数组下移,比对2数组j+1位和1数组的i位。);
当比对到相同元素时加入到交数组中。
因为题目要求每个元素出现次数得和在数组里一样,所以不用像“两数组的交”一样需要特殊处理了。
3.代码
class Solution {public: /** * @param nums1 an integer array * @param nums2 an integer array * @return an integer array */ vector<int> intersection(vector<int>& nums1, vector<int>& nums2) { // Write your code here vector<int> re; int i=0; int j=0; sort(nums1.begin(),nums1.end()); sort(nums2.begin(),nums2.end()); while(i<nums1.size()&&j<nums2.size()) { if(nums1[i]<nums2[j]) i++; if(nums1[i]>nums2[j]) j++; if(nums1[i]==nums2[j]) { re.push_back(nums1[i]); i++; j++; } } return re; }};
4.感想
本来看题目以为“两数组的交 II ”会比“两数组的交 ”要难,,没想到这道题比 “两数组的交 ”要简单一些。不用其他的处理,直接找到相同元素就可以加到新数组中。。
如果是先做了另一道题,这道题就显得很简单了。
阅读全文
0 0
- Lintcode——两数组的交 II
- LintCode:两数组的交 II
- LintCode 548 两数组的交 II
- LintCode【两数组的交II】
- 【lintcode笔记】两数组的交 II
- LintCode-两数组的交 II
- lintcode 两数组的交II
- 两数组的交 II -LintCode
- LintCode 两数组的交 II
- 两数组的交 II-LintCode
- Lintcode——两数组的交
- lintcode 547两数组的交 lintcode 548两数组的交II
- LintCode做题记录-两数组的交 II
- lintcode 刷题-两数组的交 II Python
- LintCode-[容易] 548. 两数组的交II
- LintCode:两数组的交
- LintCode:两数组的交
- 两数组的交-LintCode
- 倒计时
- hdoj1052 Tian Ji -- The Horse Racing(贪心算法+2)
- 为兼容IE8 使用layer弹框简记
- Ajax的基础知识
- 控制随机数生成概率的一种解决方法
- Lintcode——两数组的交 II
- 数据白化
- win10 wifi断开连接
- Java 网络编程
- Java并发库
- mybatis 入门笔记
- error LNK2001: 无法解析的外部符号 "public: virtual struct QMetaObject const * __thiscall Widget::metaObject
- 刷题--二叉树的镜像
- NumPy 特殊例程