List去除重复数据问题

List存放了{1,2} {2,3} {3,2}
我只想输出{1,2} {2,3}

[code="java"]public class dropList {

public static void main(String[] args) {
    String[][] mylist = new String[][]{{"1","2"},{"3","2"},{"2","3"}};
    List<String[]> list = Arrays.asList(mylist); 
    TreeSet<String[]> ts  = new TreeSet<String[]>(new Comparator<String[]>(){

        @Override
        public int compare(String[] o1, String[] o2) {
            TreeSet<String> set1 = new TreeSet<String>(Arrays.asList(o1));
            TreeSet<String> set2 = new TreeSet<String>(Arrays.asList(o2));
            Collection<String> sub =  CollectionUtils.disjunction(set1, set2);
            if (sub.size()==0) {
                return 0;
            }
            String p = sub.iterator().next();
            if(set1.contains(p)){
                return 1;
            }
            return -1;
        }

    });

    ts.addAll(list);
    for(String[] temp : ts ){
        System.out.println(Arrays.toString(temp));
    }
}

}
[/code]

treeSet {treeSet ,treeSet}

数据结构的基本知识,请使用Set或其相关子类。

关键在于list中放的是什么类型的对象。比如HashMap,HashSet还是其他什么类型,
{1,2}和{2,3}是数组还是什么?

把{1,2} {2,3} {3,2} 转成HashSet,{2,3}和{3,2}应该就一样了

排序分组不就行了

我还是直接给你贴代码吧,基本思路就是根据Set中的数据不能重复实现的……
[code]
/**
* list去重复
* @param list
* @return
*/
public static List removeDuplicateWithOrder(List list) {
Set set = new HashSet();
List newList = new ArrayList();
for (Iterator iterator = list.iterator(); iterator.hasNext();) {
BorrowedRecord record = iterator.next();
String objectId = record.getObjectId();
if (set.add(objectId))
newList.add(record);
}
return newList;
}
[/code]

你这里放在list里面的是什么对象呢?之前做过类似的事情,因为set集合判断是否相等是通过hashcode判断的,所以java的基本数据类型和自定义的对象可能不太一样
比如:
[code="java"]
Set set = new HashSet();
String s1 = new String("s");
String s2 = new String("s");
set.add(s1);
set.add(s2);
System.out.println(set.size());//打印1

Set set = new HashSet();
User u1 = new User(1,"张三");
User u2 = new User(1,"张三");
set.add(u1);
set.add(u2);
System.out.println(set.size());//打印2
[/code]
而且我搞不清楚为什么你的{2,3}和{3,2}会是相等的,他们是用什么数据结构存放的?

说说我的思路吧。
首先肯定是要遍历list,遍历的时候把list的每个节点拿出来排序一次,然后{2,3},{3,2}都会变成{2,3},然后定义一个HashMap,每个节点取出来之后节点里面的值拼接为字符串,比如{1,2}拼接为"12",{2,3}拼接为"23",然后将拼接的字符串作为key,排序后的节点作为value插入HashMap中,这样的话最后得到的HashMap就是去除重复节点的结果了,转换成List就行了。

如果是我,我会这样做:

首先,重写 List 中的对象的 equals 方法。List 中的对象:{1,2}、{2,3}、{3,2},定义为:

[code="java"]
public class MyObj{
int key1;
int key2;

//get/set 方法,略

//下面的方法,把 {2,3} 和 {3,2} 判断为相等
public boolean equals(Object obj) {
...
}
[/code]

然后,新建一个空的 LinkedHashSet,把 list 中的数据用 addAll 方法全部加入进去(这里,加入过程中,set 会判断并发现 {2,3}{3,2} 相等,就不会把后面的对象加入到 set 中,而只保留前面一个。用 LinkedHashSet 是为了保持 list 一样的顺序,如果不关心顺序,直接用 HashSet 即可);

最后,把 list 用 clear 方法清空,再把 set 的内容全部加入到 list 中去。这样,list 中就是一个没有重复元素的列表了。

用set就可以去除重复。