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…

Maven编译时,如何忽略swagger注解

public class School implements Serializable {private static final long serialVersionUID 1595261592489L;ApiModelProperty(value "主键")private Long id;ApiModelProperty(value "学校名称")private String name;ApiModelProperty(value "…

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

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

python桶排序

桶排序是一种分布式排序算法&#xff0c;它将待排序的元素分散到不同的桶中&#xff0c;然后对每个桶中的元素进行排序&#xff0c;最后按照桶的顺序将所有元素合并起来。 桶排序的基本思想是将待排序的元素分散到若干个有序的桶中&#xff0c;然后对每个桶中的元素进行排序&a…

SpringBoot 操作Redis

Redis的Java客户端 Redis的Java客户端常用的有&#xff1a; JedisLettuceSpring Data Redis Spring Data Redis是Spring的一部分&#xff0c;对Redis底层开发包进行了高度封装。在Spring项目中&#xff0c;可以使用Spring Data Redis来简化操作。 Spring Data Redis使用方式…

基于面向对象,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;每日一句…

Jmeter 压测接口返回大量数据时吞吐量上不去问题记录

1. 背景介绍 近期需要对外部提供一个批量查询接口&#xff0c;接口逻辑并不复杂&#xff0c;只是返回的数据有点多。分页查询&#xff0c;最大查询100个单子&#xff0c;分页单页最大值没有限制&#xff0c;那么&#xff0c;极端情况下&#xff0c;就是一次查询100个单…

【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 //练习 4-10 另一种方法是通过getline函数读入整个输入行,这种情况下可以不使用getch与ungetch函数。请运用这一方法修改计算器程序。

C程序设计语言 &#xff08;第二版&#xff09; 练习 4-10 练习 4-10 另一种方法是通过getline函数读入整个输入行&#xff0c;这种情况下可以不使用getch与ungetch函数。请运用这一方法修改计算器程序。 注意&#xff1a;代码在win32控制台运行&#xff0c;在不同的IDE环境下…

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

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

【Java 干货教程】Java方法引用详解

导言 Java方法引用是Java 8引入的一项重要特性&#xff0c;它提供了一种简洁、可读性高的方式来直接引用已经存在的方法。方法引用使得代码更加简洁、易懂&#xff0c;同时提高了代码的可维护性和重用性。本文将详细介绍Java方法引用的概念、语法和使用方法&#xff0c;并提供…

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

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

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

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

关于Golang闭包

关于Golang闭包 1、能不用闭包的地方就不要用闭包&#xff0c;没必要为了炫技&#xff0c;写一段增加团队小伙伴负担的代码 2、for 循环代码&#xff0c;统一在内部用临时变量再存一下 for _, val : range values {val : val }在线代码演示&#xff1a;https://go.dev/play/p…