黑马程序员技术交流社区

标题: 请教一些问题, [打印本页]

作者: clh    时间: 2014-9-15 13:26
标题: 请教一些问题,
  1. /*
  2. 有五个学生,每个学生有3门课的成绩
  3. 从键盘输入以上数据(包括姓名,三门课成绩),
  4. 输入的格式:如,zhangsan,30,40,60计算出总成绩
  5. 并把学生的信息和计算出的总分数高低顺序存放在磁盘文件“stud.txt”中

  6. 1,描述学生对象
  7. 2,定义一个可操作学生对象的工具类

  8. 思想:
  9. 1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象
  10. 2,因为学生有很多,那么就需要存储,使用到集合,因为要对学生的总分排序
  11.         所以可以使用TreeSet
  12. 3,将集合的信息写入到一个文件中


  13. */
  14. //毕姥爷第20天09练习
  15. import java.io.*;
  16. import java.util.*;

  17. class Student implements Comparable<Student>
  18. {
  19.         private String name;
  20.         private int ma,cn,en;
  21.         private int sum;

  22.         Student(String name,int ma,int cn,int en)        //学生类,定义一些基本数据类型,及方法
  23.         {
  24.                 this.name = name;
  25.                 this.ma = ma;
  26.                 this.cn = cn;
  27.                 this.en = en;
  28.                 sum = ma + cn + en;
  29.         }

  30.         public int compareTo(Student s)                              <font color="#ff0000">/*</font><span style="color: rgb(255, 0, 0); line-height: 2.2em;">用来比较排序,</span><span style="color: rgb(255, 0, 0); line-height: 2.2em;">我的理解是这样的,但是,代码只有在这里定义,却没有调用,</span>
复制代码





作者: clh    时间: 2014-9-15 13:36
  1. /*
  2. 有五个学生,每个学生有3门课的成绩
  3. 从键盘输入以上数据(包括姓名,三门课成绩),
  4. 输入的格式:如,zhangsan,30,40,60计算出总成绩
  5. 并把学生的信息和计算出的总分数高低顺序存放在磁盘文件“stud.txt”中

  6. 1,描述学生对象
  7. 2,定义一个可操作学生对象的工具类

  8. 思想:
  9. 1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象
  10. 2,因为学生有很多,那么就需要存储,使用到集合,因为要对学生的总分排序
  11.         所以可以使用TreeSet
  12. 3,将集合的信息写入到一个文件中


  13. */

  14. import java.io.*;
  15. import java.util.*;

  16. class Student implements Comparable<Student>
  17. {
  18.         private String name;
  19.         private int ma,cn,en;
  20.         private int sum;

  21.         Student(String name,int ma,int cn,int en)      
  22.         {
  23.                 this.name = name;
  24.                 this.ma = ma;
  25.                 this.cn = cn;
  26.                 this.en = en;
  27.                 sum = ma + cn + en;
  28.         }

  29.         public int compareTo(Student s)                    <font color="#ff0000">/*这个方法只有定义却没有调用,
  30.         注意到这个方法实现了Comparable接口,该方法是对其方法实现,想问下,是不是类继承接口后,类中复写
  31.         接口中的方法会自动实现,另外,这个方法是怎么实现,假如,我要输入多个学生数据,,他该怎么去比较这些 学生的数据,
  32.         是跟下面的Treeset有关么,具体怎么样的*/</font>
  33.         {
  34.                 int num = new Integer(this.sum).compareTo(new Integer(s.sum));
  35.                 if(num==0)
  36.                         return this.name.compareTo(s.name);
  37.                 return num;
  38.         }

  39.         public String getName()
  40.         {
  41.                 return name;
  42.         }

  43.         public int getSum()
  44.         {
  45.                 return sum;
  46.         }

  47.         public int hashCode()
  48.         {
  49.                 return name.hashCode()+sum*78;<font color="#ff0000">//这里是获取哈希码(作用是什么来着,我忘了,提点下),
  50.                 //最后干嘛要加上sum*78呢,非得这样么</font>
  51.         }

  52.         public boolean equals(Object obj)
  53.         {
  54.                 if(!(obj instanceof Student))
  55.                         throw new ClassCastException("类型不匹配");
  56.                 Student s = (Student)obj;

  57.                 return this.name.equals(s.name) && this.sum==s.sum;
  58.         }

  59.         public String toString()
  60.         {
  61.                 return "student ["+name+","+ma+","+cn+","+en+"]";
  62.         }
  63. }

  64. class StudentInfoTool
  65. {
  66.         public static Set<Student> getStudents() throws IOException
  67.         {
  68.                 return getStudents(null);
  69.         }

  70.         public static Set<Student> getStudents(Comparator<Student> cmp) throws IOException
  71.         {
  72.                 BufferedReader bufr =
  73.                         new BufferedReader(new InputStreamReader(System.in));

  74.                 String line = null;
  75.                
  76.                 Set<Student> stus = null;
  77.                 if(cmp==null)
  78.                         stus = new TreeSet<Student>();
  79.                 else
  80.                         stus = new TreeSet<Student>(cmp);
  81.         //        Set<Student> stus = new TreeSet<Student>(cmp);
  82.                 while((line=bufr.readLine())!=null)
  83.                 {
  84.                         if("over".equals(line))
  85.                                 break;

  86.                         String[] info = line.split(",");

  87.                         Student stu = new Student(info[0],Integer.parseInt(info[1]),
  88.                                                                                         Integer.parseInt(info[2]),
  89.                                                                                         Integer.parseInt(info[3]));

  90.                         stus.add(stu);
  91.                 }
  92.                 bufr.close();

  93.                 return stus;
  94.         }

  95.         public static void write2File(Set<Student> stus) throws IOException
  96.         {
  97.                 BufferedWriter bufw = new BufferedWriter(new FileWriter("stuinfo.txt"));

  98.                 for(Student stu:stus)
  99.                 {
  100.                         bufw.write(stu.toString()+"\t");
  101.                         bufw.write(stu.getSum()+"");
  102.                         bufw.newLine();
  103.                         bufw.flush();
  104.                 }
  105.                 bufw.close();
  106.         }
  107. }

  108. class  StudentInfoTest
  109. {
  110.         public static void main(String[] args) throws IOException
  111.         {
  112.                 Comparator<Student> cmp = Collections.reverseOrder();//反转比较器
  113.                 Set<Student> stus = StudentInfoTool.getStudents(cmp);
  114.                 StudentInfoTool.write2File(stus);
  115.         }
  116. }
复制代码

代码在这里上面的有问题






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