Given two arrays, write a function to compute their intersection.
Example:
Given nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2, 2].
Note:
Each element in the result should appear as many times as it shows in both arrays.
The result can be in any order.
参照《程序员面试金典》字符串那章,有类似的题目。
这道题http://blog.youkuaiyun.com/xd_yu/article/details/51705646的升级版,也很简单。
public class Solution {
public int[] intersect(int[] nums1, int[] nums2) {
int len=100000;
int[] temp1=new int[len];
int[] temp2=new int[len];
int[] temp=new int[len];
for(int i=0;i<nums1.length;i++){
temp1[nums1[i]]++;
}
for(int i=0;i<nums2.length;i++){
temp2[nums2[i]]++;
}
int count=0;
for(int i=0;i<len;i++){
if(temp1[i]!=0&&temp2[i]!=0){
temp[i]=temp1[i]>temp2[i]?temp2[i]:temp1[i];
count+=temp[i];
}
}
int[] result=new int[count];
int pos=0;
for(int i=0;i<len;i++){
if(temp1[i]!=0&&temp2[i]!=0){
for(int j=0;j<temp[i];j++){
result[pos]=i;
pos++;
}
}
}
return result;
}
}
本文介绍了一个计算两个整数数组交集的方法,通过使用计数数组来统计元素出现次数,并返回两个数组中共有的元素及其重复次数。
123

被折叠的 条评论
为什么被折叠?



