/*
* 需求:删除集合里重复的字符串
*
* 思路:一、首先添加字符串
* 二、开始遍历字符串,同时创建一个正则表达式
* 三、遍历过的字符串进行判断,若符合规则,则删除,若不符合规则,则保留并把该字符串添加进正则表达式
*/
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));
}
}
}
首先我按照固化的思路,将出现过的字符串写入规则当中,结果发现规则会越来越多,就不能正确的去匹配,就好比你那一个太阳去跟卫星比较,然后我就换一个思路,把药比较的字符串当作规则,把出现过的字符串集合当作要比较的对象,就成功了
删除集合里重复的字符串
最新推荐文章于 2021-05-17 03:11:50 发布