第十五周上机任务项目4—多科成绩单

01./*      
02.* 程序的版权和版本声明部分      
03.* Copyright (c)2012, 烟台大学计算机学院学生      
04.* All rightsreserved.      
05.* 文件名称:score .cpp                                 
06.* 作    者:赵冠哲                                  
07.* 完成日期:2012年12月13日      
08.* 版本号: v1.0            
09.* 输入描述:几名学生的高数,英语,C++成绩      
10.* 问题描述:求其总分,最低分,最高分,标准差。
11.*/       
#include <iostream>
#include<cmath>
#include<string>
using namespace std;
void input(double s[][4],int n);
double max(double s[][4],int n,int i);
double min(double s[][4],int n,int i);
double avg(double s[][4],int n,int i);
double stdev(double s[][4],int n,int i);
output_result(double s[][4],int n);  

int main(void)
{
	double score[100][4];
	int num,i;
	string step;
	string course[4]={"高等数学","英语","C++"};
	cout<<"请输入学生人数:";
	cin>>num;
	cout<<"请依次输入学生的高数,英语,C++成绩:"<<endl;
	for(i=0;i<num;++i)
	{
		cin>>score[i][0]>>score[i][1]>>score[i][2];
		score[i][3]=score[i][0]+score[i][1]+score[i][2];
	}
	cout<<"学号"<<" "<<" 高数"<<" "<<" 英语"<<" "<<"C++"<<" "<<" 总分"<<endl;
	for(i=0;i<num;++i)
	{
		cout<<i<<"    "<<score[i][0]<<"    "<<score[i][1]<<"    "<<score[i][2]<<"    "<<score[i][3]<<endl;
	}
	for(i=0;i<4;++i)
    {
        cout<<course[i]<<"的最高成绩是"<<max(score,num,i)<<", ";
		cout<<endl;
        cout<<"      最低成绩是"<<min(score,num,i)<<", ";
		cout<<endl;
        cout<<"      平均成绩是"<<avg(score,num,i)<<", ";
		cout<<endl;
        cout<<"      成绩的标准偏差是"<<stdev(score,num,i)<<endl;
    }
    output_result(score,num);
	return 0;
}

double max(double s[][4],int n,int j)  
{  
    double m=s[0][j];  
    for(int i=1;i<n;++i)  
        if (m<s[i][j])   
            m=s[i][j];  
        return m;  
}  
double min(double s[][4],int n,int j)  
{  
	double m=s[0][j];  
    for(int i=1;i<n;++i)  
        if (m>s[i][j])   
			m=s[i][j];  
        return m;  
}  
double avg(double s[][4],int n,int j)  
{  
    double sum=s[0][j];  
    for(int i=1;i<n;++i)  
        sum+=s[i][j];  
    return sum/n;  
}  
double stdev(double s[][4],int n,int j)  
{  
    double a,x,sum=0;  
    a=avg(s,n,j);
    for(int i=0;i<n;i++)    
    {    
        x=s[i][j]-a;    
        sum+=x*x;    
    }    
    return sqrt(sum/(n-1));    
} 

output_result(double s[][4],int n)  
{  
    double m=max(s,n,3);  
    int i,c=0;  
    bool first=true;  
    cout<<"总分最高分为"<<m;  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)   
            ++c;  
    }  
    cout<<",有"<<c<<"人达到最高分,他们的学号是:";  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)  
            if(first)  
            {  
                cout<<i;  
                first=false;  
            }  
            else  
            {  
                cout<<"、"<<i;  
            }  
    }  
    cout<<endl;    
	m=min(s,n,3);  
	c=0;  
    first=true;  
    cout<<"总分最低分为"<<m;  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)   
            ++c;  
    }  
    cout<<",有"<<c<<"人达到最低分,他们的学号是:";  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)  
            if(first)  
            {  
                cout<<i;  
                first=false;  
            }  
			else  
            {  
                cout<<"、"<<i;  
            }  
    }  
    cout<<endl;  
}  


运行结果:

心得体会:

就这个程序,在我的草稿箱里放了很久,每次更改各种error,弄的头都大了,非常无语,鉴于这周把十六周的任务全部顺利完成,这才乘着上机的机会把这个程序好好修改,后来干脆看着贺老的修改,终于写成了。。。大哭大哭大哭奋斗奋斗奋斗

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值