1. 程式人生 > >第十三週 專案三 成績處理模板

第十三週 專案三 成績處理模板

<span style="font-size:14px;">多檔案組織的應用對複雜的程式設計很方便</span>
<span style="font-size:14px;">/*
*copyright (c) 2014.煙大計算機學院
*All rights reserved.
*檔名稱:
*作者:王爭取
*完成日期:2014.11.
*版 本 號:v1.0
*問題描述:成績處理
*輸入描述:輸入班級內人數和成績
*程式輸出:最大值和最小值及取得最大值和最小值的人數和學號
平均成績,標準差
*/
#include <iostream>
using namespace std;
voidinput_score(int s[],int n);
intget_max_score(int s[], int n);
intget_min_score(int s[],int n);
doubleget_ave_score(int s[],int n);
doubleget_stdv_score(int score[],int n);
int count(intx,int s[],int n);
voidoutput_index(intx,int s[],int n);
int main()
{
int n;
intmax_score,min_score;
cout<<"請輸入該小組人數n:";
cin>>n;
int score[n];
cout<<endl<<"請輸入學生成績:"<<endl;
input_score(score,n);
max_score=get_max_score(score,n);
min_score=get_min_score(score,n);
cout<<endl<<"最高成績為:"<<max_score<<",共有:"<<count(max_score,score,n)<<"人"<<endl;
cout<<endl<<"最低成績為:"<<get_min_score(score,n);
cout<<",共有"<<count(min_score,score,n)<<"人"<<endl;
cout<<"平均成績為:"<<get_ave_score(score,n)<<endl;
cout<<"標準差為:"<<get_stdv_score(score,n)<<endl;
cout<<"獲得最高成績的學生編號有:";
output_index(max_score,score,n);
cout<<"獲得最低成績的學生編號有:";
output_index(min_score,score,n);
return 0;
}
<span style="color:#3366ff;">input_score.cpp</span>
#include <iostream>
using namespace std;
intinput_score(int s[],int n)
{
inti,score;
for(i=1; i<n+1;1)
    {

cout<<"輸入第"<<i<<"位同學的成績:";
cin>>score;
        if(score<0||score>100) cout<<"請輸入成績在0-100的成績"<<endl;
else
        {
s[i]=score;
i++;
        }
    }
}
</span><span style="font-size:18px;color:#3366ff;"><strong>get_max_score.cpp</strong></span><span style="font-size:14px;">
#include <iostream>
using namespace std;
intget_max_score(int s[], int n)
{
int max=-1,i;
for(i=1; i<n+1; i++)
if(s[i]>max)max=s[i];
return max;
}
<strong style="background-color: rgb(255, 255, 255);"><span style="color:#3366ff;">get_min_score.cpp</span></strong>
#include <iostream>
using namespace std;
intget_min_score(int s[],int n)
{
int min=100,i;
for(i=1; i<n+1; i++)
if(min>s[i])min=s[i];
return min;
}
<span style="color:#3366ff;">get_ave_score.cpp</span>
#include <iostream>
using namespace std;
doubleget_ave_score(int s[],int n)
{inti,sum=0,aver;
for(i=1; i<n+1; i++)
sum+=s[i];
aver=sum/n;
return aver;
}
<span style="color:#3366ff;">count.cpp</span>
#include <iostream>
using namespace std;
int count(intx,int s[],int n)
{
int i,n1=0;
for(i=1; i<n+1; i++)
    {
if(s[i]==x)
n1++;
    }
return n1;
}
<span style="color:#3366ff;">get_stdv_score.cpp</span>
#include <cmath>
#include <iostream>
using namespace std;
doubleget_stdv_score(int s[],int n)
{
int s1=0,m,i,sum=0,aver;
for(i=1; i<n+1; i++)
sum+=s[i];
aver=sum/n;
for(i=1; i<n+1; i++)
s1+=(s[i]-aver)*(s[i]-aver);
    m=sqrt(s1/(n-1));
return m;
}
<span style="color:#3366ff;">output_index.cpp</span>
#include <iostream>
using namespace std;
voidoutput_index(intx,int s[],int n)
{inti;
for(i=1; i<n+1; i++)
if(s[i]==x)
cout<<i<<" ";
}
</span>
<span style="font-size:14px;"><img src="" alt="" />
</span>
<span style="font-size:14px;"><img src="https://img-blog.csdn.net/20141125101729091?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2FuZ3poZW5ncXU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
</span>

總結:多實踐,多撞錯,在錯誤中也許成長更快