Java面试 字符串去重

字符串 String str1 = “AAAAAABBCC”;
去掉重复的字符串,使结果等于“ABC”。
这个网上的回答很多,无非就是新建一个List集合,判断是否包含,如果说不包含,再将其添加到StringBuffer中,但是考虑性能问题的话,我们新建了两个对象,会增加内存的消耗。
我们知道StringBuffer和StringBuilder都是字符串的缓冲类,区别就是StringBuffer是一个安全的,调用append方法时,内部使用synchronized修饰的,执行速度较慢,相对于适合用于线程并发的状况,而StringBuilder则是直接添加,速度快,但是不安全,对于我们上面那种情况,使用StringBuilder可能相对来说性能更好一些。
同样的,我们一般使用的是ArrayLis进行添加,ArrayList底层封装的是数组,数组的特性就是查询快,增删慢,我们在字符串去重的时候,需要用contains判断集合中是否已经存在这个字符串,也要使用add添加集合中没有的字符串,我们在遍历的时候,每次都要判断contains一次,而add却不见得会调用几次。
contains内部调用的是什么呢?
contains 内部也是遍历查询是否存在
由此我们看到使用ArrayList相对来说使比LinkedList(基于链表,增删快,查询慢)要好一些。
单纯说效率问题的话,使用HashMap和HashSet会不会更好呢?(恶补了一下数据结构QAQ)
HashMap的特性可以说是 增删快,查找慢。
但是HashSet却被称之为查询最快的,天生就是为提高查找效率的,那是不是会更适合一些呢?
HashSet实现的是Set接口,内部初始化了一个HashMap,HashMap底层使用的数组和链表,其中就涉及到了加载因子和容量这两个概念,如果说拼接数据量比较大的话,可以改一下加载因子的大小。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值