C++,STL 029(24.10.13)

内容

一道练习题。

(涉及string,vector,deque,sort)

题目(大致)

有五名选手ABCDE,10个评委分别对每一个选手打分,去除最高分和最低分,取平均分。

思路(总体)

(1)创建类Class来记录每个人的姓名和最终成绩(平均分);

(2)用vector容器来装入类Class;

(3)10个评委的打分用deque容器来记录并处理,从而得到最终成绩(平均分)。

代码

cpp 复制代码
#include <iostream>
#include <string>
#include <vector>
#include <deque>
#include <algorithm>
#include <ctime>

using namespace std;

// 创建类Class来记录每个人的姓名和最终成绩(平均分)
class Person
{
public:
    string m_Name;
    int m_Score; // 最终成绩(平均分)

public:
    Person(string name, int score)
    {
        this->m_Name = name;
        this->m_Score = score;
    }
};

// 用vector容器来装入类Class,并对选手信息进行初步处理
void creatPerson(vector<Person> &v)
{
    string nameSeed = "ABCDE";
    for (int i = 0; i < 5; i++)
    {
        string name = "Player ";
        name += nameSeed[i];

        int score = 0;
        Person p(name, score);

        v.push_back(p);
    }
}

// 10个评委的打分用deque容器来记录并处理,从而得到最终成绩(平均分)
void setScore(vector<Person> &v)
{
    for (vector<Person>::iterator it = v.begin(); it != v.end(); it++)
    {
        deque<int> d;
        for (int i = 0; i < 10; i++)
        {
            int score = rand() % 41 + 60; // ???
            d.push_back(score);
        }

        /*
        检测成绩是否已成功录入
        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 showPerson(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)); // ???

    vector<Person> v;

    creatPerson(v);
    setScore(v);
    showPerson(v);

    /*
    检测vector容器是否成功已装入 类Class
    for (vector<Person>::iterator it = v.begin(); it != v.end(); it++)
    {
        cout << (*it).m_Name << " " << (*it).m_Score << endl;
    }
    */

    return 0;
}

输出结果(不唯一)

其他

关于代码中???的部分,待续。

相关推荐
Gary Studio43 分钟前
rk芯片驱动编写
linux·学习
mango_mangojuice1 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
工程师老罗1 小时前
YOLOv1 核心知识点笔记
笔记·yolo
lingggggaaaa1 小时前
安全工具篇&动态绕过&DumpLsass凭据&Certutil下载&变异替换&打乱源头特征
学习·安全·web安全·免杀对抗
MZ_ZXD0011 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
PP东1 小时前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
学电子她就能回来吗1 小时前
深度学习速成:损失函数与反向传播
人工智能·深度学习·学习·计算机视觉·github
A星空1232 小时前
一、Linux嵌入式的I2C驱动开发
linux·c++·驱动开发·i2c
半壶清水2 小时前
[软考网规考点笔记]-软件开发、项目管理与知识产权核心知识与真题解析
网络·笔记·压力测试
凡人叶枫3 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发