java-给定两个已排序序列,找出共同的元素。
import java.util.ArrayList;import java.util.Arrays;import java.util.List;public class CommonItemInTwoSortedArray {/** * 题目:给定两个已排序序列,找出共同的元素。 * 1.定义两个指针分别指向序列的开始。 * 如果指向的两个元素相等,则找到一个相同的元素;如果不等,则将指向较小元素的指针向前移动。 * 重复执行上面的步骤,直到有一个指针指向序列尾端。 * 2.如果数组大小差得很多,就遍历小的,然后在大的里二分查找 */public static void main(String[] args) {int[] a={1,3,5,7};int[] b={2,3,4,5,6,8};List<Integer> c=findCommonItems(a,b);for(int each:c){System.out.print(each+" ");}}public static List<Integer> findCommonItems(int[] a,int[] b){List<Integer> commonList=new ArrayList<Integer>();if(!(a!=null&&a.length>0&&b!=null&&b.length>0)){return commonList;}int lenA=a.length;int lenB=b.length;/*if(lenA<lenB){//how do we know lenB is much bigger than lenA? lenB>=100*lenA? or lenB>=1000*lenA?...for(int each:a){int index=Arrays.binarySearch(b,each);//we can write our own binarySearch for practice.if(index>=0){commonList.add(each);}}return commonList;}*/for(int i=0,j=0;i<lenA&&j<lenB;){if(a[i]<b[j]){i++;}else if(a[i]==b[j]){commonList.add(a[i]);i++;j++;}else if(a[i]>b[j]){j++;}}return commonList;}}