c++学习笔记-STL案例-演讲比赛管理系统2

目录

功能介绍

代码结构部分

查看一下类图 

1.Speaker.h  

2.speechManager.h

3.speechManager.cpp

4.演讲比赛流程关系系统.cpp


功能介绍

speechManager.h函数包含演讲比赛流程的所有功能如下:

开始演讲比赛:完成整届比赛的流程,每个比赛阶段需要给用户一个提示,用户按任意键进入下一个比赛阶段

查看往届记录:查看之前比赛前三名结果,每次比赛都会记录到文件中,文件用.csv后缀保存

清空比赛记录:将文件中数据清空

退出比赛程序:可以退出当前程序

//构造函数
    SpeechManager();

    //菜单功能
    void show_Menu();

    //退出系统
    void exitSystem();

//析构
    ~SpeechManager();

    //创建12名选手
    void creatSpeaker();

    //开始比赛  比赛流程的控制函数
    void startSpeech();

    //抽签
    void speechDraw();

    //比赛函数
    void speechContest();

    //显示得分
    void showScore();

    //保存分数
    void saveScore();

    //读取往届信息
    void loadRecord();

    //文件为空标志位
    bool fileIsEmpty;

    //往届记录
    map<int, vector<string>>m_Record;

    //查看往届得分
    void showRecord();

    //清空记录
    void clearRecord();


    //初始化容器和属性
    void initSpeech();

    //成员属性
    //保存第一轮选手编号的容器
    vector<int> v1;
    
    //保存第二轮选手编号的容器
    vector<int>v2;

    //保存前三名选手编号容器
    vector<int>vVictory;

    //存放编号对应选手
    map<int, Speaker> m_Speaker;

    //存放比赛轮数
    int m_Index;
    

代码结构部分

查看一下类图 

分析类图:

Speaker类创建选手,选手信息包括姓名、得分

变量名变量类型范围描述
m_Namestring-选手姓名
m_Scoredouble0-100选手得分

 

SpeechManager类

变量名变量类型范围描述
v1vector<int>-保存第一轮选手编号的容器
v2vector<int>-保存第二轮选手编号的容器
vVictoryvector<int>-保存前三名选手编号容器
m_Indexint-存放比赛轮数
m_Recordmap<int,vector<string>>-
m_Speakermap<int,Speaker> -存放编号对应选手
fileIsEmptybool-文件为空标志位

的字段v1、V2、vVictory用于分别对应存储:第一轮选手编号姓名和得分、第二轮编号姓名和得分、前三名选手编号姓名和得分 ;字段m_Index存储历史记录的届数,m_Record

1.Speaker.h  

#pragma once
#include<iostream>
using namespace std;//选手类
class Speaker
{
public:string m_Name;double m_Score[2];//最多两轮得分
};

2.speechManager.h

#pragma once
#include<iostream>
using namespace std;
#include<vector>
#include<map>
#include"Speaker.h"
#include<algorithm>
#include<deque>
#include<functional>  //内建函数greater<double>()
#include<numeric>   //accumulate
#include<fstream>
//设计演讲管理类
class SpeechManager
{
public://构造函数SpeechManager();//菜单功能void show_Menu();//退出系统void exitSystem();//析构~SpeechManager();//创建12名选手void creatSpeaker();//开始比赛  比赛流程的控制函数void startSpeech();//抽签void speechDraw();//比赛函数void speechContest();//显示得分void showScore();//保存分数void saveScore();//读取往届信息void loadRecord();//文件为空标志位bool fileIsEmpty;//往届记录map<int, vector<string>>m_Record;//查看往届得分void showRecord();//清空记录void clearRecord();//初始化容器和属性void initSpeech();//成员属性//保存第一轮选手编号的容器vector<int> v1;//保存第二轮选手编号的容器vector<int>v2;//保存前三名选手编号容器vector<int>vVictory;//存放编号对应选手map<int, Speaker> m_Speaker;//存放比赛轮数int m_Index;};

3.speechManager.cpp

#include"speechManager.h"//构造函数
SpeechManager::SpeechManager()
{//初始化容器和属性this->initSpeech();//创建12名选手this->creatSpeaker();//加载往届记录this->loadRecord();
}void SpeechManager::show_Menu()
{cout << "**************************************" << endl;cout << "***********欢迎参加演讲比赛***********" << endl;cout << "************1.开始演讲比赛************" << endl;cout << "************2.查看往届记录************" << endl;cout << "************3.清空比赛记录************" << endl;cout << "************0.退出比赛程序************" << endl;cout << "**************************************" << endl;}void SpeechManager::exitSystem()
{cout << "欢迎下次使用" << endl;system("pause");exit(0);
}void SpeechManager::showRecord()
{if (this->fileIsEmpty){cout << "文件为空或不存在!" << endl;}else{for (int i = 0; i < this->m_Record.size(); i++){cout << "第" << i + 1 << "届"<< "  冠军编号:" << this->m_Record[i][0] << "  得分:" << this->m_Record[i][1] << "  "<< "  亚军编号:" << this->m_Record[i][2] << "  得分:" << this->m_Record[i][3] << "  "<< "  季军编号:" << this->m_Record[i][4] << "  得分:" << this->m_Record[i][5] << endl;}}system("pause");system("cls");
}//清空记录
void SpeechManager::clearRecord()
{cout << "是否清空?" << endl;cout << "1.确认" << endl;cout << "2.返回" << endl;int select;cin >> select;if (select == 1){//确认清空ofstream ofs("speech.csv", ios::trunc);//trunc删除并重新创建新文件ofs.close();//初始化容器和属性this->initSpeech();//创建12名选手this->creatSpeaker();//加载往届记录this->loadRecord();}system("pause");system("cls");
}void SpeechManager::initSpeech()
{//容器都置空this->v1.clear();this->v2.clear();this->vVictory.clear();this->m_Speaker.clear();//初始化比赛轮数this->m_Index = 1;//初始化记录容器this->m_Record.clear();}void SpeechManager::creatSpeaker()
{string nameSeed = "ABCDEFGHIJKL";for (int i = 0; i < nameSeed.size(); i++){string name = "选手";name += nameSeed[i];//创建具体选手Speaker sp;sp.m_Name = name;for (int j = 0; j < 2; j++){sp.m_Score[j] = 0;}//创建选手的编号  并放到v1容器中this->v1.push_back(i + 10001);//选手编号+选手  放入map容器中this->m_Speaker.insert(make_pair(i + 10001, sp));}}//开始比赛  比赛整个流程控制函数
void SpeechManager::startSpeech()
{//第一轮开始比赛//1、抽签this->speechDraw();//2、比赛this->speechContest();//3、显示晋级结果this->showScore();//第二轮开始比赛this->m_Index++;//1、抽签this->speechDraw();//2、比赛this->speechContest();//3、显示最终结果this->showScore();//4、保存最终结果this->saveScore();//重置比赛并获取记录//初始化容器和属性this->initSpeech();//创建12名选手this->creatSpeaker();//加载往届记录this->loadRecord();cout << "本届比赛完毕!" << endl;system("pause");system("cls");
}void SpeechManager::speechDraw()
{cout << "第<<" << this->m_Index << ">>轮比赛选手正在抽签" << endl;cout << "------------------------------------------" << endl;cout << "抽取后的演讲顺序如下:" << endl;if (this->m_Index == 1){//第一轮的比赛random_shuffle(v1.begin(), v1.end());for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++){cout << *it << "  ";}cout << endl;}else{//第二轮比赛random_shuffle(v2.begin(), v2.end());for (vector<int>::iterator it = v2.begin(); it != v2.end(); it++){cout << *it << "  ";}cout << endl;}cout << "------------------------------------------" << endl;system("pause");cout << endl;
}void SpeechManager::speechContest()
{cout << "--------第<<" << this->m_Index << ">>轮比赛正式开始--------" << endl;//准备临时容器  存放小组成绩multimap<double, int, greater<double>> groupScore;int num = 0;// 记录人员个数vector<int>v_Src;//比赛选手容器if (m_Index == 1){v_Src = v1;}else{v_Src = v2;}//所有的选手进行比赛for (vector<int>::iterator it = v_Src.begin(); it != v_Src.end(); it++){num++;//评委打分deque<double>d;for (int i = 0; i < 10; i++){double score = (rand() % 401 + 600) / 10.f;   //600~1000//cout << score << "  ";d.push_back(score);}//cout << endl;sort(d.begin(), d.end(), greater<double>());//排序 从大到小d.pop_front();//去除最高分d.pop_back();//去除最低分double sum = accumulate(d.begin(), d.end(), 0);   //分数求和double avg = sum / (double)d.size();    //平均分//打印平均分//cout << "编号: " << *it << "  姓名:" << this->m_Speaker[*it].m_Name << "  平均分" << avg;//将平均分放入map容器this->m_Speaker[*it].m_Score[this->m_Index - 1] = avg;//cout << endl;//将打分数据放入临时小组容器中groupScore.insert(make_pair(avg, *it));//key是得分,value是具体选手编号//六人取出前三名if (num % 6 == 0){cout << "第 " << num / 6 << " 小组比赛名次:" << endl;for (multimap<double, int, greater<double>>::iterator it = groupScore.begin(); it != groupScore.end(); it++){cout << "编号: " << it->second << "  姓名:" << this->m_Speaker[it->second].m_Name << "  成绩:"<< this->m_Speaker[it->second].m_Score[this->m_Index - 1] << endl;}//取走前三名int count = 0;for (multimap<double, int, greater<double>>::iterator it = groupScore.begin(); it != groupScore.end() && count<3; it++,count++){if (this->m_Index == 1){v2.push_back((*it).second);}else{vVictory.push_back((*it).second);}}groupScore.clear();//小组容器清空cout << endl;}}cout<<"--------第<<" << this->m_Index << ">>轮比赛完毕!--------" << endl;system("pause");
}//查看往届记录
void SpeechManager::showScore()
{cout << "-----------------第" << this->m_Index << "轮晋级选手信息如下:-----------------" << endl;vector<int>v;if (this->m_Index == 1){v = v2;}else{v = vVictory;}for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << "选手编号:" << *it << "  姓名:" << this->m_Speaker[*it].m_Name << "  得分:" <<this->m_Speaker[*it].m_Score[this->m_Index - 1] << endl;}cout << endl;system("pause");system("cls");this->show_Menu();}void SpeechManager::saveScore()
{ofstream ofs;ofs.open("speech.csv", ios::out | ios::app);//用追加的方式写文件//将每个选手数据写入文件中for (vector<int>::iterator it = vVictory.begin(); it != vVictory.end(); it++){ofs << *it << "," << this->m_Speaker[*it].m_Score[1] << ",";}ofs << endl;ofs.close();cout << "记录已经保存" << endl;//更改文件不为空状态this->fileIsEmpty = false;}void SpeechManager::loadRecord()
{ifstream ifs("speech.csv", ios::in);//读文件if (!ifs.is_open()){this->fileIsEmpty = true;//cout << "文件不存在" << endl;ifs.close();return;}//文件清空char ch;ifs >> ch;if (ifs.eof()){//cout << "文件为空" << endl;this->fileIsEmpty = true;ifs.close();return;}//文件不为空this->fileIsEmpty = false;ifs.putback(ch);//将上面读取的单个字符再放回int index = 0;string data;while (ifs >> data){//cout << data << endl;//10002,86.375,10009,81,10010,78,vector<string>v;//存放6个string字符串int pos = -1;//查到","位置的变量int start = 0;while (true){pos = data.find(",", start);if (pos == -1){//没有找到的情况break;}string temp = data.substr(start, pos - start);//cout << temp << endl;v.push_back(temp);start = pos + 1;}this->m_Record.insert(make_pair(index, v));index++;}ifs.close();/*for (map<int, vector<string>> ::iterator it = m_Record.begin(); it != m_Record.end(); it++){cout << "第 "<<it->first<<" 届" << "    冠军编号:" << it->second[0] << "  分数:" << it->second[1] << endl;}*/
}//析构函数
SpeechManager::~SpeechManager()
{}

4.演讲比赛流程关系系统.cpp

#include<iostream>
using namespace std;
#include"speechManager.h"
#include<ctime>int main()
{//添加随机数种子srand((unsigned int)time(NULL));//创建管理类的对象SpeechManager sm;测试12名选手创建//for (map<int, Speaker>::iterator it = sm.m_Speaker.begin(); it != sm.m_Speaker.end(); it++)//{//	cout << "选手编号:" << it->first << "   姓名:" << it->second.m_Name << "   分数" << it->second.m_Score[0] << endl;//}int choice = 0; //用于存储用户while (true){sm.show_Menu();cout << "请输入您的选择:" << endl;cin >> choice;switch (choice){case 1:  //开始比赛sm.startSpeech();break;case 2:  //查看往届记录sm.showRecord();break;case 3:  //清空比赛记录sm.clearRecord();break;case 0:  //退出比赛程序sm.exitSystem();break;default:system("cls");  //清屏break;}}system("pause");return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/622584.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构.线性表(2)

一、模板 例子&#xff1a; a: b: 二、基本操作的实现 &#xff08;1&#xff09;初始化 &#xff08;2&#xff09;销毁和清空 &#xff08;3&#xff09;求长度和判断是否为空 &#xff08;4&#xff09;取值 &#xff08;5&#xff09;查找 &#xff08;6&#xff09;插入 &…

【期末考试】数据库综合复习宝典

目录 第一章 数据库系统概述 第二章 关系代数 第四章 关系数据库理论 第五章 数据库设计 第六章 数据库管理系统 第八章 事务管理 第一章 数据库系统概述 1.1三级模式 ①外模式&#xff1a;它为特定的应用程序或用户群体提供了一个数据视图&#xff0c;这个视图是独立于…

Maven和MyBatis框架简单实现数据库交互

MyBatis是一种基于Java语言的持久层框架&#xff0c;它的主要目的是简化与数据库的交互过程。MyBatis通过XML或注解配置来映射Java对象和数据库表之间的关系&#xff0c;并提供了灵活的查询方式和结果集处理机制。MyBatis还提供了事务管理、缓存机制、插件扩展等特性。 使用My…

Linux学习记录——사십 高级IO(1)

文章目录 1、IO2、同、异步IO&#xff08;5种IO类型&#xff09;3、其它高级IO4、非阻塞IO 其它IO类型的实现在这篇之后的三篇 1、IO input&#xff0c;output。调用read或recv接口时&#xff0c;如果对方长时间不向我方接收缓冲区拷贝数据&#xff0c;我们的进程就只能阻塞&a…

基于面向对象,C++实现双链表

双链表同单链表类似&#xff0c;由一个值和两个指针组成 Node.h节点头文件 #pragma once class Node { public:int value;Node* prev;Node* next;Node(int value);~Node(); };Node.cpp节点源文件 #include "Node.h"Node::Node(int value) {this->value value…

如何开启文件共享及其他设备如何获取

1.场景分析 日常生活中&#xff0c;常常会遇到多台电脑共同办公文件却不能共享的问题&#xff0c;频繁的用移动硬盘、U盘等拷贝很是繁琐&#xff0c;鉴于此&#xff0c;可以在同一内网环境下设置共享文件夹&#xff0c;减少不必要的文件拷贝工作&#xff0c;提升工作效率。废话…

希尔排序和计数排序

&#x1f4d1;前言 本文主要是【排序】——希尔排序、计数排序的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1f304;每日一句…

【PyTorch简介】3.Loading and normalizing datasets 加载和规范化数据集

Loading and normalizing datasets 加载和规范化数据集 文章目录 Loading and normalizing datasets 加载和规范化数据集Datasets & DataLoaders 数据集和数据加载器Loading a Dataset 加载数据集Iterating and Visualizing the Dataset 迭代和可视化数据集Creating a Cust…

【Docker篇】从0到1搭建自己的镜像仓库并且推送镜像到自己的仓库中

文章目录 &#x1f50e;docker私有仓库&#x1f354;具体步骤 &#x1f50e;docker私有仓库 Docker私有仓库的存在为用户提供了更高的灵活性、控制和安全性。与使用公共镜像仓库相比&#xff0c;私有仓库使用户能够完全掌握自己的镜像生命周期。 首先&#xff0c;私有仓库允许…

力扣-盛最多水的容器

11.盛最多水的容器 给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。找出其中的两条线&#xff0c;使得它们与 x 轴共同构成的容器可以容纳最多的水。返回容器可以储存的最大水量。 说明&#xff1a;你不能倾斜…

C语言程序设计——程序流程控制方法(二)

循环结构 while语句 while(表达式){代码块; }do{代码块; }while(表达式)while语句分为do-while和while两种&#xff0c;区别在于循环之前是不是先执行一次循环的内容&#xff0c;可以类似于i和i的关系&#xff0c;本质上来讲是相同的。当表达式为真时&#xff0c;则会执行一次…

超详细的 pytest 钩子函数 之初始钩子和引导钩子来啦

前几篇文章介绍了 pytest 点的基本使用&#xff0c;学完前面几篇的内容基本上就可以满足工作中编写用例和进行自动化测试的需求。从这篇文章开始会陆续给大家介绍 pytest 中的钩子函数&#xff0c;插件开发等等。 仔细去看过 pytest 文档的小伙伴&#xff0c;应该都有发现 pyte…

【数据结构 | 希尔排序法】

希尔排序法 思路ShellSort 思路 希尔排序法又称缩小增量法。希尔排序法的基本思想是&#xff1a;先选定一个整数&#xff0c;把待排序文件中所有记录分成个组&#xff0c;所有距离为的记录分在同一组内&#xff0c;并对每一组内的记录进行排序。然后&#xff0c;取&#xff0c…

ospf-gre隧道小练习

全网可达,R5路由表没有其他路由器的路由条目 注:每个路由器都添加了自己的环回,如R1就是1.1.1.1 R1可以分别ping通与R2,R3,R4之间的隧道 R1路由表上有所有路由器环回的路由条目 R5路由表上没有其他路由器的路由条目 实现代码: 首先将各个接口IP配好 边上3个路由器:[R6][R7][R…

ES API 批量操作 Bulk API

bulk 是 elasticsearch 提供的一种批量增删改的操作API。 bulk 对 JSON串 有着严格的要求。每个JSON串 不能换行 &#xff0c;只能放在同一行&#xff0c;同时&#xff0c; 相邻的JSON串之间必须要有换行 &#xff08;Linux下是\n&#xff1b;Window下是\r\n&#xff09;。bul…

【谭浩强C程序设计 学习辅导第3章】最简单的C程序设计——顺序程序设计(含详细源码)

文章目录 一、 顺序程序设计题的解题思路及注意事项解题思路注意事项 二、源码讲解第3章源码文件构成&#xff1a;main.c 文件内容说明chap3.c源码实现chap3.h声明头文件测试结果展示源码链接 说明&#xff1a;本学习辅导题适用于谭浩强教辅第四版。 一、 顺序程序设计题的解题…

Programming Abstractions in C阅读笔记:p246-p247

《Programming Abstractions in C》学习第68天&#xff0c;p246-p247总结&#xff0c;总计2页。 一、技术总结 本章通过“the game of nim(尼姆游戏)”&#xff0c;这类以现实生活中事物作为例子进行讲解的情况&#xff0c;往往对学习者要求比较高&#xff0c;需要学习者具备…

<软考高项备考>《论文专题 - 65 质量管理(4) 》

4 过程3-管理质量 4.1 问题 4W1H过程做什么为了评估绩效&#xff0c;确保项目输出完整、正确且满足客户期望&#xff0c;而监督和记录质量管理活动执行结果的过程作用&#xff1a;①核实项目可交付成果和工作已经达到主要干系人的质量要求&#xff0c;可供最终验收;②确定项目…

C# 静态代码织入AOP组件之肉夹馍

写在前面 关于肉夹馍组件的官方介绍说明&#xff1a; Rougamo是一个静态代码织入的AOP组件&#xff0c;同为AOP组件较为常用的有Castle、Autofac、AspectCore等&#xff0c;与这些组件不同的是&#xff0c;这些组件基本都是通过动态代理IoC的方式实现AOP&#xff0c;是运行时…

【Web】CTFSHOW PHP特性刷题记录(全)

知其然知其所以然&#xff0c;尽量把每种特性都详细讲明白。 目录 web89 web90 web91 web92 web93 web94 web95 web96 web97 web98 web99 web100 web101 web102 web103 web104 web105 web106 web107 web108 web109 web110 web111 web112 web113 web…