早就想用容器类来实现一些编程,今天也算是学了一点吧。

vector的使用方法参考了某位博主的一篇文章,感觉写得还是不错的:http://blog.csdn.net/always2015/article/details/44976729

然后还根据c++ primer plus 898 的#include<algorithm> 中的sort 来进行排序了。附上代码:

#include <iostream>
#include<math.h>
#include <iomanip>
#include<cstdio>
#include<string>
#include<map>
#include<vector>
#include<algorithm>
#include<stdlib.h>
using namespace std;

int main()
{

    int num,n;
     double sum=0;
    while(cin>>num)
   {
       vector<int> score;
       while(num--){

        cin>>n;
        score.push_back(n);
       }

        sort(score.begin(),score.end());//对vector进行排序
        score.erase(score.begin());//下面两个掐头去尾
        score.erase(score.end()-1);//end 指向的是最后一个元素的后一位 所以end-1

        int j=score.size();//大小

        for(int i=0;i<j;i++){
            sum=sum+score[i];
        }
        cout<<fixed<<setprecision(2)<<sum/j<<endl;
        sum=0;
   }


    return 0;
}

然后附上不用STL 的代码:

#include <iostream>
#include<iomanip>
using namespace std;

int main()
{
    int n,*judge_person,max_num,min_num,total_num=0;
    float average;
    while(cin>>n)
    {
        //为评委人数分配空间
        judge_person=new int[n];

        for(int i=0; i<n; i++)
        {
            //存储每个评委的打分
            cin>>judge_person[i];

            if(i==0)
            {
                //刚开始将最大最小值都赋给第一个评委的打分
                max_num=judge_person[i];
                min_num=judge_person[i];
            }
            //比较得出最大值
            if(judge_person[i]>max_num)
                max_num=judge_person[i];
            //比较得出最小值
            if(judge_person[i]<min_num)
                min_num=judge_person[i];
            //对所有评委的打分进行累加
            total_num+=judge_person[i];

        }
        //求除去最高分和最低分后的平均分
        average=(float)(total_num-max_num-min_num)/(n-2);
        //格式输出
        cout<<setiosflags(ios::fixed)<<setprecision(2)<<average<<endl;
        //清零,进入下一个循环
        total_num=0;
    }
    return 0;
}