15_学生信息的存储与排序
来源:互联网 发布:seo的站外优化流程 编辑:程序博客网 时间:2024/06/15 09:30
有五个学生,每个学生有3门课的成绩。
从键盘输入以上数据(包括姓名,三门成绩),
输入的格式,如:zhangsan,30,40,60计算出总成绩,
并把学生的信息和计算出的总分数按高低顺序存放都在磁盘文件“stud.txt”中。
1,描述学生对象。
2,定义一个课操作学生对象的工具类。
思想:
1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象。
2,因为学生很多,那么就需要存储,使用到集合。因为要对学生的总分排序。所以可以使用TreeSet。
3,将集合的信息写入到一个文件中。
从键盘输入以上数据(包括姓名,三门成绩),
输入的格式,如:zhangsan,30,40,60计算出总成绩,
并把学生的信息和计算出的总分数按高低顺序存放都在磁盘文件“stud.txt”中。
1,描述学生对象。
2,定义一个课操作学生对象的工具类。
思想:
1,通过获取键盘录入一行数据,并将该行中的信息取出封装成学生对象。
2,因为学生很多,那么就需要存储,使用到集合。因为要对学生的总分排序。所以可以使用TreeSet。
3,将集合的信息写入到一个文件中。
import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.FileWriter;import java.io.IOException;import java.io.InputStreamReader;import java.util.Collections;import java.util.Comparator;import java.util.Set;import java.util.TreeSet;public class Demo {public static void main(String[] args) throws Exception {// TODO Auto-generated method stub//反转比机器Comparator<Student> cmp=Collections.reverseOrder();Set<Student> stus=StudentInfoTool.getStudents(cmp);StudentInfoTool.write2File(stus);}}class Student implements Comparable<Student>{private String name;private int math,cn,eng;private int sum;public Student(String name, int math, int cn, int eng) {this.name = name;this.math = math;this.cn = cn;this.eng = eng;this.sum=math+cn+eng;}public String getName() {return name;}public int getSum() {return sum;}@Overridepublic int compareTo(Student o) {// TODO Auto-generated method stubint num=new Integer(this.sum).compareTo(new Integer(o.sum));if(num==0)return this.name.compareTo(o.name);return num;}@Overridepublic boolean equals(Object obj) {// TODO Auto-generated method stubif(!(obj instanceof Student))throw new ClassCastException("类型不匹配");Student s=(Student)obj;return this.name.equals(s.name)&&this.sum==s.sum;}@Overridepublic int hashCode() {// TODO Auto-generated method stubreturn this.name.hashCode()+sum*11;}@Overridepublic String toString() {// TODO Auto-generated method stubreturn "Student["+name+", "+math+", "+cn+", "+eng+"]";}}class StudentInfoTool{public static Set<Student> getStudents() throws Exception{return getStudents(null);}public static Set<Student> getStudents(Comparator<Student> cmp) throws Exception{BufferedReader bufr=new BufferedReader(new InputStreamReader(System.in));String line=null;Set<Student> stud=null;if(cmp==null)stud=new TreeSet<Student>();elsestud=new TreeSet<Student>(cmp);while((line=bufr.readLine())!=null){if("over".equals(line))break;String [] info=line.split(",");Student stu=new Student(info[0],Integer.parseInt(info[1]),Integer.parseInt(info[2]),Integer.parseInt(info[3]));stud.add(stu);}bufr.close();return stud;}public static void write2File(Set<Student> stus) throws IOException{BufferedWriter bufw=new BufferedWriter(new FileWriter("D:\\a\\stu.txt"));for(Student stu:stus){bufw.write(stu.toString()+"\t");bufw.write(stu.getSum()+"");bufw.newLine();bufw.flush();}bufw.close();}}
0 0
- 15_学生信息的存储与排序
- 黑马程序员_学生信息本地存储练习
- 用链表来实现学生信息的存储
- 存储班长信息的学生类
- 存储班长信息的学生类
- 存储班长信息的学生类
- 存储班长信息的学生类
- 存储班长信息的学生类
- 11.1 存储班长信息的学生类
- 存储班长信息的学生类
- 存储班长信息的学生类
- 11.1存储班长信息的学生类
- 11.1存储班长学生的信息类
- 存储班长信息的学生类2
- 存储班长信息的学生类
- 存储班长信息的学生类
- 存储班长信息的学生类(1)
- 存储班长信息的学生类
- 【4】单机游戏序列化与反序列化
- hdu4734(数位DP)
- Fuse文件系统优化方案
- TCP 与 UDP的区别 java
- 新的一天新的开始
- 15_学生信息的存储与排序
- 《黑马程序员》 使用反射获取字节码文件中的方法
- 普通查找与二分法
- 浮点数的陷阱 转载自(taesimple)
- vim入门教程
- IOS几种简单有效的数组排序方法
- VS2010中文书写时出现的文字提醒原因及去除方法
- HIVE RCFile高效存储结构
- Spring如何解决循环依赖