删除集合里重复的字符串

/*
 * 需求:删除集合里重复的字符串
 * 
 * 思路:一、首先添加字符串
 * 	        二、开始遍历字符串,同时创建一个正则表达式
 * 		三、遍历过的字符串进行判断,若符合规则,则删除,若不符合规则,则保留并把该字符串添加进正则表达式
 */

import java.util.ArrayList;
import java.util.ListIterator;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class ArrayListDemo {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ArrayList<String>arrayList=new ArrayList<String>();
		
		arrayList.add("风清扬");
		arrayList.add("李莫愁");
		arrayList.add("东方不败");
		arrayList.add("李莫愁");
		arrayList.add("西门庆");
		arrayList.add("风清扬");
		arrayList.add("孙悟空");
		arrayList.add("风清扬");
		arrayList.add("李莫愁");
		arrayList.add("风清扬");
		
		StringBuffer regex=new StringBuffer("1");
		ListIterator<String> lit=arrayList.listIterator();
		while(lit.hasNext()){
			String temp=lit.next();
			Pattern p=Pattern.compile(temp);//这两句很关键!
			Matcher m=p.matcher(regex.toString());
			if(m.find()){
				lit.remove();
			}else{
				regex.append(temp);
			}
		}
		for(int i=0;i<arrayList.size();i++){
			System.out.println(arrayList.get(i));
			
		}
		
	}

}
首先我按照固化的思路,将出现过的字符串写入规则当中,结果发现规则会越来越多,就不能正确的去匹配,就好比你那一个太阳去跟卫星比较,然后我就换一个思路,把药比较的字符串当作规则,把出现过的字符串集合当作要比较的对象,就成功了

你可能感兴趣的:(删除集合里重复的字符串)