编写一个成绩排名程序(java实现)

  • 要求:
    首先从文件中读入一组学生的姓名、学号、成绩,其中,姓名为一个字符串,学号为一个整数,成绩为一个实数,每位学生的信息占用一行,如“Yeuying 20050923 95.5”。然后对这些学生的成绩进行排序,并将排序后的结果保存在另一个文件中。在该文件中,除了原有的姓名、学号和成绩以外,在增加排名信息。

  • 源代码:

package qi_mo;

import java.io.*;
import java.util.*;

public class Test4 {
	static int num = 0;
	public static void main(String[] args) throws FileNotFoundException{
		Scanner fenshu = new Scanner(new File("student.txt"));
		double []arr = new double[100];
		while(fenshu.hasNext()){
			if(fenshu.hasNextDouble()){
  				arr[num++] = fenshu.nextDouble();	
			}
			else fenshu.next();
		}
		try{
			FileReader fr = new FileReader("student.txt"); 
			FileWriter fw = new FileWriter("newstudent.txt");  
	        int ch;  
	        while((ch = fr.read()) != -1){  
	             fw.write(ch);  
	         }
	        fr.close();  
	        fw.close();  
			FileOutputStream fos = new FileOutputStream("newstudent.txt",true);  
			fos.write(sort(arr).getBytes()); 
			fos.close();
		}catch(IOException ex){
			System.out.println("无法打开文件!");
		}
	}
	//将学生成绩进行排序
	public static String sort(double score[]){
		int i;
		String str = "\r\n成绩排名为: ";
		for(i = num - 2;i >= 0;i--){
			for(int j = 0;j <= i;j++){
				if(score[j] < score[j+1]){
					double temp;
					temp = score[j];
					score[j] = score[j+1];
					score[j+1] = temp;
				}
			}
		}
		for(int n = 0;n < num;n++){
			str += score[n] + " ";
		}
		return str;
	}
}

  • 测试结果:
    排序前:
    编写一个成绩排名程序(java实现)

排序后:
编写一个成绩排名程序(java实现)