黑马程序员技术交流社区

标题: 迭代器的嵌套...偶受不鸟啦!! [打印本页]

作者: 黑马连家华    时间: 2012-5-3 20:53
标题: 迭代器的嵌套...偶受不鸟啦!!
本帖最后由 黑马连家华 于 2012-8-13 17:24 编辑

/*
存入学生对象(成员有name和age),要求对应所在班级存储
*/
import java.util.*;
class Student implements Comparable<Student>
{
        private String name;
        private int age;
        Student(String name,int age)
        {
                this.name = name;
                this.age = age;
        }
        public String getName()
        {
                return name;
        }
        public int getAge()
        {
                return age;
        }
        public int hashCode()
        {
                return this.name.hashCode()+this.age*13;
        }
        public boolean equals(Object obj)
        {
                if (!(obj instanceof Student))
                {
                        throw new ClassCastException("不是同一类");
                }
                Student stu = (Student)obj;
                return this.name.equals(stu.name) && this.age == stu.age;
        }
        public int compareTo(Student stu)
        {
                int num = this.name.compareTo(stu.name);
                if (num == 0)
                {
                        return new Integer(this.age).compareTo(new Integer(stu.age));
                }
                return num;
        }
}
class Exercise4
{
        public static void main(String[] args)
        {
                //建立集合这个集合里面是教室和学生对象
                TreeMap<String,Student> classes = new TreeMap<String,Student>();
                classes.put("Base",new Student("ZhanSan",18));
                classes.put("Base",new Student("LiSi",22));
                classes.put("Adv",new Student("Wangwu",25));
                classes.put("Adv",new Student("ZhaoLiu",22));
                //取出教室与学生的关系
                Set<Map.Entry<String,Student>> es = classes.entrySet();
                for (Iterator<Map.Entry<String,Student>> it = es.iterator();it.hasNext() ; )
                {
                        Map.Entry<String,Student> me = it.next();
                        //取出教室,并打印
                        System.out.println(me.getKey());
                        //然后如何使用迭代器取出教室里的学生????????????
                        
                        
                }
        }
}

作者: 魏征    时间: 2012-5-3 21:53
本帖最后由 魏征 于 2012-5-3 23:04 编辑

TreeMap<String,TreeSet> classes=new TreeMap<String,TreeSet>();
TreeSet<Student> Base=new TreeSet<Student>();
TreeSet<Student> Adv=new TreeSet<Student>();
Base.add(new Student("ZhanSan",18));
Base.add(new Student("LiSi",22));
Adv.add(new Student("Wangwu",25));
Adv.add(new Student("ZhaoLiu",22));
classes.put("base",Base);
classes.put("adv",Adv);
Set<Map.entry<String,TreeSet>> s1=classes.entrySet();
Iterator<Map.entry<String,TreeSet>>  it=s1.iterator();
while(it.hasNext())
{
     Map.entry<String,TreeSet>>  me=it.next();
     String key=me.keySet();
     Treeset ts=me.valueSet();
     System.out.println(key);
      Iterator<Student> it1=ts.iterator();
      while(it1.hasNext())
      {
          Student s=it1.next();
          System.out.println(s.getName()+s.getAge());
       }

}



作者: 魏征    时间: 2012-5-3 22:11
本帖最后由 魏征 于 2012-5-3 22:12 编辑

楼主你这种做法是取不出来的,TreeMap的键是唯一的,
                classes.put("Base",new Student("ZhanSan",18));
                classes.put("Base",new Student("LiSi",22));
这样子的做法就是当键相同时,第二行的值把第一行的值覆盖了。

作者: 陈苓    时间: 2012-5-3 22:32
  Set<Map.Entry<String,Integer>> es= classes.entrySet();
  for(Map.Entry<String,Student> me : es) {
   System.out.println(me.getKey() + ":" + me.getValue());
  }
这里用我的是for增强哈,照样行
作者: 隋营营    时间: 2012-5-4 08:24
本帖最后由 隋营营 于 2012-5-4 08:26 编辑

我在main中修改了一下,您看行不?
public static void main(String[] args) {
        TreeMap<String, Student[]> classes = new TreeMap<String, Student[]>();
        classes.put("Base", new Student[] { new Student("LiSi", 22),
                new Student("ZhanSan", 18) });

        classes.put("Adv", new Student[] { new Student("ZhaoLiu", 22),
                new Student("Wangwu", 25) });
        Set<Map.Entry<String, Student[]>> es = classes.entrySet();
        for (Iterator<Map.Entry<String, Student[]>> it = es.iterator(); it.hasNext();) {
            Map.Entry<String, Student[]> me = it.next();
            String name = me.getKey();
            Student[] values = me.getValue();
            if (1 == values.length) {
                System.out.println(values[0]);
            } else {
                for (int i = 0; i < values.length; i++) {
                    System.out.println(values);
                }
            }

        }
}

就是把key相同的value值存放到Student[]数组中,然后取值时,就能得到一个Student[]


作者: 隋营营    时间: 2012-5-4 20:45
隋营营 发表于 2012-5-4 08:24
我在main中修改了一下,您看行不?
public static void main(String[] args) {
        TreeMap classes =  ...

这么精彩的回答要加分!




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2