面试考到的问题

Code:
  1. /**
  2. *有两个字符串数组a和b,寻找相同元素(a和b都比较大),求效率最高的解答
  3. *
  4. *@authorAdministrator2010-5-29
  5. */
  6. //第一种方法:基本思路:相同=集合2-(集合2-集合1中相同的)
  7. publicstaticvoidgetSameElementByList(String[]strArr1,String[]strArr2){
  8. Longbegin=System.currentTimeMillis();
  9. List<String>list1=newArrayList<String>(Arrays.asList(strArr1));
  10. List<String>list02=newArrayList<String>(Arrays.asList(strArr2));
  11. List<String>list12=newArrayList<String>(Arrays.asList(strArr2));
  12. list02.removeAll(list1);
  13. Iterator<String>it=list02.iterator();
  14. while(it.hasNext()){
  15. System.out.println(it.next());
  16. }
  17. System.out.println("-------华丽的分割线-----------");
  18. list12.removeAll(list02);
  19. Iterator<String>it2=list12.iterator();
  20. while(it2.hasNext()){
  21. System.out.println(it2.next());
  22. }
  23. Longend=System.currentTimeMillis();
  24. System.out.println("此方法运行共使用时间"+(end-begin)+"ms");
  25. }
  26. //第二种方法:把数组A的数据作为map的key,和value,然后用B的数据取值,不为NULL,说明相同
  27. publicstaticvoidgetSameElementByMap(String[]strArr1,String[]strArr2){
  28. Longbegin=System.currentTimeMillis();
  29. Map<String,Object>map=newHashMap<String,Object>();
  30. for(Stringstr:strArr1){
  31. map.put(str,str);
  32. }
  33. for(Stringstr2:strArr2){
  34. Objectobj=map.get(str2);
  35. if(obj!=null){
  36. System.out.println(obj.toString());
  37. }
  38. }
  39. Longend=System.currentTimeMillis();
  40. System.out.println("此方法运行共使用时间"+(end-begin)+"ms");
  41. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值