Map map =new HashMap();
map.put(1,"zs");
map.put(2,"lisi");
map.put(3,"ww");
map.put(4,"zs");
如何形成一个遍历集合map并且删除后面相同的value?
public class Demo01{
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) {
Map map =new HashMap();
map.put(1,"zs");
map.put(2,"lisi");
map.put(3,"ww");
map.put(4,"zs");
Collection list=map.values();
ArrayList<String> lists=new ArrayList<String>(list);
Set set=new HashSet<String>(lists);
System.out.println(lists);
System.out.println(set);
}
}
public static void main(String[] args) {
Map map =new HashMap();
map.put(1,"zs");
map.put(2,"lisi");
map.put(3,"ww");
map.put(4,"zs");
Collection list=map.values();
ArrayList<String> lists=new ArrayList<String>(list);
Iterator it=lists.listIterator();
while(it.hasNext()){
if(it.next()=="zs"){
it.remove();
}
}
System.out.println(lists);
}
}
但是这样做就把相同的都是删除了
public class Demo01{
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) {
Map map =new HashMap();
map.put(0,"zs");
map.put(1,"lisi");
map.put(2,"ww");
map.put(3,"zs");
map.put(4, "as");
Collection list=map.values();
ArrayList<String> lists=new ArrayList<String>(list);
System.out.println(lists.size());
for(int i=0;i<lists.size();i++){
String str=lists.get(i);
for(int j=i+1;j<list.size()-1;j++){
String str1=lists.get(j);
if(str.equals(str1)){
lists.remove(j);
}
}
}
System.out.println(lists);
这个代码的问题需要大家想一下,我也没想明白问题出在哪。。。。数组下表越界。。。。