-
要求:
首先从文件中读入一组学生的姓名、学号、成绩,其中,姓名为一个字符串,学号为一个整数,成绩为一个实数,每位学生的信息占用一行,如“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;
}
}
- 测试结果:
排序前:
排序后: