首页 > 其他分享 >案例--评委打分

案例--评委打分

时间:2024-12-24 22:20:01浏览次数:3  
标签:deque iterator -- ++ int vector dit 评委 打分

案例描述:

有5名选手:选手ABCBE,10个评委分别对每一名选手打分,去除最高分,去除评委中最低分,取平均分。

实现步骤

1.创建五名选手,放到vector中
2.遍历vector容器,取出来每一个选手,执行for循环,可以把10个评分打分存到deque容器中
3. sort算法对deque容器中分数排序,去除最高和最低分
4.deque容器遍历一遍,累加总分
5.获取平均分

示例:

#include <iostream>
using namespace std;
#include <deque>
#include <algorithm>  // 标准算法头文件
#include <vector>
#include <string>
#include <ctime>

//deque容器排序
class Person
{
public:
    Person(string name, int score)
    {
        this->m_Name = name;
        this->m_Score = score;
    }
    string m_Name;//姓名
    int m_Score;//平均分
};
// void printDeque(const deque<int>&d)
// {
//     for (deque<int>::const_iterator it = d.begin(); it != d.end(); it++)
//     {
//         cout << *it << " ";
//     }
//     cout << endl;
// }
void creatPerson(vector<Person>&v)
{
    string nameSeed="ABCDE";
    for (int i = 0; i < 5; i++)
    { 
        string name="选手";
        name+=nameSeed[i];

        int score=0;

        Person p(name,score);
        //将创建的Person对象放入到容器中
        v.push_back(p);
    }
    
}
void setScrore(vector<Person>&v)
{
    for (vector<Person>::iterator it = v.begin(); it!=v.end(); it++)
    {
        //将评委的分数放入到deque容器中
        deque<int>d;
        for (int i = 0; i < 10; i++)
        {
            int score=rand()%41+60;//60-100
            d.push_back(score);
        }

        // cout<<"选手:"<<it->m_Name<<"打分:"<<endl;
        // for (deque<int>::iterator dit =d.begin() ; dit!=d.end(); dit++)
        // {
        //     cout<<*dit<<" ";
        // }
        // cout<<endl;

        //排序
        sort(d.begin(),d.end());

        //去除最高分和最低分
        d.pop_back();
        d.pop_front();

        //取平均分
        int sum=0;
        for (deque<int>::iterator dit = d.begin(); dit!=d.end(); dit++)
        {
            sum+=*dit;//累加每个评委的分数
        }
        int avg=sum/d.size();

        //将平均分赋值给选手身上
        it->m_Score=avg;
    }
};
void showScore(vector<Person>&v) 
{
    for (vector<Person>::iterator it = v.begin(); it!=v.end(); it++)
    {
        cout<<"姓名:"<<it->m_Name<<"平均分:"<<it->m_Score<<endl;
    }
}
int main()
{
    //随机数种子
    srand((unsigned int)time(NULL));

    //1.创建5名选手
    vector<Person>v;//存放选手容器
    creatPerson(v);

    //测试
    // for (vector<Person>::iterator it = v.begin(); it!=v.end(); it++)
    // {
    //     cout<<"姓名:"<<(*it).m_Name<<"分数:"<<(*it).m_Score<<endl;
    // }
    
    //2.给5名选手打分
     setScrore(v);
    //3.显示最后得分
    showScore(v);
   return 0;
}

标签:deque,iterator,--,++,int,vector,dit,评委,打分
From: https://www.cnblogs.com/RX1Ri/p/18628533

相关文章

  • vue-固定某列使用fixed失效问题
    1.如下图,有时候前端需要固定最左边或最右边的某1列或好几列,但是页面会出现无法对齐的现象2.博主问题场景原因分析:  前端列表一行里会出现高度不一致的情况,比如可能遇到某一列定义windth不够而换行显示会导致表格的高度发生变化从而导致无法对齐的现象3.解决方......
  • OpenCL 编程步骤 5. 创建内存对象
    参考《AMDOpenCL大学教程》OpenCL内存对象就是一些OpenCL数据,这些数据一般在设备内存中,能够被拷入也能够被拷出。OpenCL内存对象包括buffer对象和image对象。Buffer对象:连续的内存块----顺序存储,能够通过指针、行列式等直接访问。Image对象:是2维或3维的......
  • Linux之权限管理
    Linux系统之所以更安全,是因为对文件权限有着非常严格的控制。查看文件或目录的权限:ls-al文件权限分别为:读(read),写(write),执行(execute),简写即为(r,w,x),-即无权限。每个文件针对每类访问者定义了三种主要权限。其中,第一位:代表文件类型,后面每3位代表一组权限,分别是:所有者、所属......
  • Mysql存储引擎(InnoDB-事务原理)
    1、什么是事务    事务是一组命令的集合,要么全部成功,要么都不成功。事务有四个特征,即原子性、一致性、隔离性、持久性。其中隔离性又有四大隔离级别,分别是读未提交,读已提交、可重复读、串行化,四大隔离级别主要解决三个现象,脏读,不可重复读,幻读。 2、事务的四大特性(A......
  • VMD-SSA-BiLSTM、VMD-BiLSTM、BiLSTM时间序列预测对比
    VMD-SSA-BiLSTM、VMD-BiLSTM、BiLSTM时间序列预测对比目录VMD-SSA-BiLSTM、VMD-BiLSTM、BiLSTM时间序列预测对比预测效果基本介绍程序设计参考资料预测效果基本介绍1.MATLAB实现VMD-SSA-BiLSTM、VMD-BiLSTM、BiLSTM时间序列预测对比;2.单变量时间序列预测就......
  • 封装(3)
    大家好,今天我们来学习一下静态方法相关的内容,这个要和普通成员做一个区分,那么它们到底有什么不同点呢,我们现在就来看看。7.2static修饰成员变量1、访问方式,通过类名静态变量不在对象里面,在方法区,要通过类名.访问.  static修饰的成员变量,称为静态成员变量,静态成负......
  • 封装(2)
    大家好,今天我们来介绍一下包的概念,知道包的作用可以更好的面对今后的开发,那么我们就来看看包是什么东西吧。6.3封装扩展之包6.3.1包的概念在面向对象体系中,提出了一个软件包的概念,即:为了更好的管理类,把多个类收集在一起成为一组,称为软件包,有点类似于目录,比如:为了更......
  • GitHub与开源社群的项目模式
    早期自由软件运动强调软件应该是自由的,用户有使用、复制、分发、研究、修改和改进软件的自由,这种理念催生了开源软件的诞生。而现代开源模式在早期自由软件运动的基础上有了一些变化。以GitHub为例,它是一个主流的代码托管、协作和社交平台,但本身是闭源的。一方面,它是和大多......
  • leetcode刷题
    思路分析对于每一个房间,只有选或不选两种结果,假设第i个房间选了那么第i-1个房间就不能选。构建状态转移方程dp[i]=max(dp[i-1],dp[i-2]+nums[i]).意思是当偷到第i个房间时,最大的结果应该在偷不偷上一个房间(dp[i-2]+nums[i]也就是偷第i-2个房间和第i个房间的金额)偷上一个房......
  • 【原创】【踩坑日记】onnx转ncnn模型出bug
    python导出的onnx格式的yolo模型为yolov11.onnx文件。输出代码如下:fromultralyticsimportYOLOmodel=YOLO("yolo11n.pt")success=model.export(format="onnx")ncnn需要两个模型文件才能推理,.param和.bin文件。官方建议使用onnx2ncnn.exe导出,这个导出的onnx格式文件(yo......