码迷,mamicode.com
首页 > 编程语言 > 详细

学生成绩管理系统(java实现)

时间:2015-06-09 11:58:08      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:java   小项目   排序   

最近在看基础的java教程,发现java很多与c++类似,但也有不少差异,有很多要注意的地方,做了这个成绩管理系统,还没用到类,只是多维数组的应用。

期间遇到很多问题,也都经过一一百度解决了。

实现的功能: 输入学生人数,以及学生考试的科目数,然后依次填入信息,最后输出学生信息,以及总分,平均分,名次;

import java.util.*;
import java.math.*;
import java.text.*;//引入控制格式的包,import java.text.DecimalFormat; 用来控制浮点数小数位数
public class Test{
	public static void main(String[] args){
		Scanner in=new Scanner(System.in);
			System.out.println("请输入一共有几门课程");
		int numberofCoarses=in.nextInt();
			System.out.println("请输入一共有几个学生");
		int numberofStudents=in.nextInt();
			System.out.println("请定义这几门课程");
		String [] coarse=new String[numberofCoarses];
		String [] name=new String[numberofStudents];
			for(int i=0;i<numberofCoarses;i++)
				coarse[i]=in.next();
		double[][] stuu =new double[numberofStudents][numberofCoarses];
		double[] totalGrades=new double [numberofStudents];
		double[] average=new double [numberofStudents];
		double[] totalsort=new double [numberofStudents];
		int[]  paihang = new int [numberofStudents];
		DecimalFormat df=new DecimalFormat("0.00");//设置浮点数的位数
			for(int i=0;i<numberofStudents;i++)
			{
				System.out.println("请输入第"+(i+1)+"个学生的名字");
				name[i]=in.next();
				System.out.println("请依次输入"+name[i]+"的"+numberofCoarses+"门成绩");
				double sum=0;
				for(int j=0;j<numberofCoarses;j++)
				{
					stuu[i][j]=in.nextDouble();
					sum+=stuu[i][j];
				}
				totalGrades[i]=sum;
				average[i]=sum/numberofCoarses;
			}
			//totalsort=totalGrades  错误,浅复制,指向同一个引用;
			//totalsort=totalGrades.clone();  //数组的深复制//用clone只能复制一维数组,多维数组需要加上for循环依次clone
			System.arraycopy(totalGrades,0,totalsort,0,totalGrades.length);  //最快的赋值 
                                                                        //第一个0,代表源数组赋值的起始位置,第二个0,代表被赋值数组的起始位置
		 	for(int i=0;i<totalsort.length-1;i++)   //选择排序
			{
				int k=i;
				for(int j=i+1;j<totalsort.length;j++)
				{
					if(totalsort[j]>totalsort[k])
					{
						k=j;
					}
				}
				if(k!=i)
				{
					double temp=totalsort[k];
					totalsort[k]=totalsort[i];
					totalsort[i]=temp;
				}
			} 
		//	Arrays.sort(totalsort,Collections.reverseOrder());  <<  有错误,改天再看看库函数怎么排序吧。。
			for(int i=0;i<paihang.length;i++)    //二分查找
			{
				int head=0,tail=paihang.length-1;
				while(head<=tail){
					if(totalsort[head]==totalGrades[i])
					{	paihang[i]=head+1;break;  }
					else if(totalsort[tail]==totalGrades[i])
					{	paihang[i]=tail+1;break;	}
					else{
						int mid=(head+tail)/2;
						if(totalsort[mid]==totalGrades[i])
						{
							paihang[i]=mid+1;break;
						}
						else if(totalsort[mid]>totalGrades[i])
						{
							tail=mid-1;
						}
						else
							head=mid+1;
					}
				}
			}
			System.out.print("学生\t");
				for(int i=0;i<numberofCoarses;i++)
					System.out.print(coarse[i]+"\t");
			System.out.println("总分\t平均分\t排行榜");
			for(int i=0;i<numberofStudents;i++)
			{
				System.out.print(name[i]+"\t");
				for(int j=0;j<stuu[i].length;j++)
				{
					System.out.print(stuu[i][j]+"\t");
				}
				System.out.print(totalGrades[i]+"\t");
				System.out.print(df.format(average[i])+"\t");
				System.out.print("第"+paihang[i]+"名");
				System.out.println();
			}
		
	}
}


学生成绩管理系统(java实现)

标签:java   小项目   排序   

原文地址:http://blog.csdn.net/chaiwenjun000/article/details/46423223

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!