string去除重复字符两个方法

string去除重复字符


今天面试遇到,使用了第一种,回来记录了下,觉得一般可能不是这样解的。想了第二种,还是觉得不妥,这里都贴出来。

网上有很多伪方法,只删除了相邻重复字符串,大家警惕!

主要使用list.contains()检测重复。


一直在想本来应该怎样做,因为面试官说了句只用了一层循环,可能这样是比较通用的:

1、charAt遍历String每个字符(第一层循环)

2、charAt遍历StringBuffer每个字符,如果没有就加进去(第二层循环)


import java.util.*;
public class Main06 {


	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str = "kjkljklhuionsd";
		System.out.println(sub(str));
		System.out.println(sub1(str));
	}
	//方法1
	static String sub(String str){
		StringBuffer result = new StringBuffer();
		List list = new ArrayList();
		char[] cs = str.toCharArray();
		for(int i=0; i<cs.length; i++){
			if(!list.contains(cs[i])){
				result.append(cs[i]);
				list.add(cs[i]);
			}
		}
		return result.toString();
	}
	//方法2
	static String sub1(String str){
		List list = new ArrayList();
		StringBuffer sb = new StringBuffer(str);
		int j=0;
		for(int i=0; i<str.length(); i++){
			if(list.contains(str.charAt(i))){
				sb.deleteCharAt(i-j);     //String 是没有delete方法的
				j++; //因为删除了sb中的字符,有一个偏移
			}else{
				list.add(str.charAt(i));
			}
		}
		return sb.toString();
	}
}

  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值