从C向C++18——演讲比赛流程管理系统

一.项目需求

1.比赛规则

  • 学校举行一场演讲比赛,共有12个人参加。比赛共两轮,第一轮为淘汰赛,第二轮为决赛。
  • 每名选手都有对应的编号,如 10001~ 10012
  • 比赛方式:分组比赛,每组6个人;
  • 第一轮分为两个小组, 整体按照选手编号进行抽签后顺序演讲.
  • 十个评委分别给每名选手打分,**去除最高分和最低分,**求的平均分为本轮选手的成绩
  • 当小组演讲完后,淘汰组内排名最后的三个选手,前三名晋级,进入下一轮的比赛
  • 第二轮为决赛,前三名胜出
  • 每轮比赛过后需要显示晋级选手的信息

2.程序功能

  • 开始演讲比赛:完成整届比赛的流程,每个比赛阶段需要给用户一个提示,用户按任意键后继续下一个阶段
  • 查看往届记录:查看之前比赛前三名结果,每次比赛都会记录到文件中,文件用.csv后缀名保存
  • 清空比赛记录:将文件中数据清空
  • 退出比赛程序:可以退出当前程序

二.界面实现

实际开发过程中,先写主界面,一些部分可以用伪代码注释,以后再慢慢实现:

#include <iostream>
#include <ctime>
#include "speechmanger.h"
using namespace std;int main()
{Speechmanger sm;int choice = 0;srand((unsigned int)time(NULL));while (true){sm.showmenu();cout << "请您输入您的选择:" << endl;cin >> choice;switch (choice){case 1:sm.startgame();                    //开始比赛break;case 2:sm.showrecord();                   //查看记录break;case 3:sm.clearfile();                    //清空文件break;case 0:sm.exitsystem();                   //退出系统break;default:system("cls");break;}}system("pause");return 0;
}

三.管理类头文件

speechmanger.h头文件:

#pragma once
#include <iostream>
#include <string>
#include "speaker.h"
#include <vector>
#include <map>
#include <algorithm>
#include <deque>
#include <functional>
#include <numeric>
#include <fstream>
using namespace std;//演讲管理类
class Speechmanger
{
public:Speechmanger();                  //构造函数~Speechmanger();                 //析构函数void showmenu();                 //显示菜单void exitsystem();               //退出系统void initspeech();               //初始化容器和属性void creatspeaker();             //创建选手void startgame();                //开始比赛void speechdraw();               //抽签void contest();                  //比赛(打分)double avg_score();              //计算成绩void showscore();                //显示得分(1)void showhonor();                //显示决赛获奖名单void saverecord();               //保存本届决赛记录void loadrecord();               //读取比赛记录void showrecord();               //显示往届记录void clearfile();                //清空文件//成员属性vector<int> v1;                  //保存第一轮选手编号vector<int> v2;                  //保存第二轮选手编号,也就是第一轮晋级选手编号vector<int> v3;                  //保存最后胜出3名选手编号map<int, Speaker> m_s;           //存放编号及其具体对应选手的容器int index;                       //记录当前比赛轮次bool fileempty;                  //文件空标志map<int, vector<string>> m_record;      //存放往届记录的容器
};

像我这样,属性和方法分开写。

四.方法实现

speechmanger.cpp源文件实现:

#include "speechmanger.h"Speechmanger::Speechmanger()
{this->initspeech();this->creatspeaker();this->loadrecord();
}Speechmanger::~Speechmanger() 
{}//显示菜单
void Speechmanger::showmenu()
{cout << "********************************************" << endl;cout << "*************  欢迎参加演讲比赛 ************" << endl;cout << "*************  1.开始演讲比赛  *************" << endl;cout << "*************  2.查看往届记录  *************" << endl;cout << "*************  3.清空比赛记录  *************" << endl;cout << "*************  0.退出比赛程序  *************" << endl;cout << "********************************************" << endl;cout << endl;
}//退出系统
void Speechmanger::exitsystem()
{cout << "欢迎下次使用" << endl;exit(0);
}//初始化容器和属性
void Speechmanger::initspeech()
{//容器都置空this->v1.clear();this->v2.clear();this->v3.clear();this->m_s.clear();this->m_record.clear();//比赛轮次初始为1this->index = 1;}//创建12名选手
void Speechmanger::creatspeaker()
{string namesed = "ABCDEFGHILKL";for (int i = 0; i < namesed.size(); i++){string name = "选手";name += namesed[i];Speaker sp;sp.m_name = name;for (int j = 0; j < 2; j++){sp.m_score[j] = 0;}this->v1.push_back(i + 10001);                       //创建选手编号,放入v1容器中this->m_s.insert(make_pair(i + 10001, sp));          //记录编号和选手对应关系}
}//开始比赛
void Speechmanger::startgame()
{//第一轮开始比赛//1.抽签this->speechdraw();//2.比赛(打分)this->contest();//3.显示晋级名单this->showscore();//第二轮开始比赛this->index++;//1.抽签this->speechdraw();//2.比赛(打分)this->contest();//3.显示获奖名单this->showhonor();//4.结果保存到文件中this->saverecord();//重置环境this->initspeech();this->creatspeaker();this->loadrecord();cout << "本届比赛结束!" << endl;system("pause");system("cls");
}//抽签
void Speechmanger::speechdraw()
{cout << "第" << this->index << "轮选手正在抽签:" << endl;cout << "--------------------------------------" << endl;cout << "抽签后的结果如下:" << endl;if (this->index == 1){random_shuffle(v1.begin(), v1.end());for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++){cout << *it << " ";}cout << endl;}else if (this->index == 2){random_shuffle(v2.begin(), v2.end());for (vector<int>::iterator it = v2.begin(); it != v2.end(); it++){cout << *it << " ";}cout << endl;}elsecout << "程序出现错误" << endl;cout << "--------------------------------------" << endl;system("pause");cout << endl;
}//比赛(打分)
void Speechmanger::contest()
{cout << "---第" << this->index << "轮比赛开始:---" << endl;vector<int> v_src;                    //比赛容器if (this->index == 1)v_src = v1;if (this->index == 2)v_src = v2;multimap<double, int, greater<double>> groupscore;             //临时容器,存放小组成绩int num = 0;                //记录人数,6个人一组//遍历所有选手开始打分for (vector<int>::iterator it = v_src.begin(); it != v_src.end(); it++){num++;double score = this->avg_score();this->m_s[*it].m_score[index - 1] = score;            //第四种插入方式groupscore.insert(make_pair(score,*it));if (num % 6 == 0){cout << "第" << num / 6 << "小组的成绩如下:" << endl;for (multimap<double, int, greater<double>>::iterator dit = groupscore.begin(); dit != groupscore.end(); dit++){cout << "编号:" << dit->second << "  姓名:" << this->m_s[dit->second].m_name<< "  成绩:" << this->m_s[dit->second].m_score[this->index - 1] << endl;}//取走前3名int count = 0;for (multimap<double, int, greater<double>>::iterator fit = groupscore.begin(); fit != groupscore.end()&& count<3; fit++,count++){if (this->index == 1){v2.push_back((*fit).second);}elsev3.push_back((*fit).second);}groupscore.clear();cout << endl;}}cout << "---第" << this->index << "轮比赛结束---" << endl;system("pause");
}//计算成绩
double Speechmanger::avg_score()
{deque<double> d;for (int i = 0; i < 10; i++){double score = (rand() % 401 + 600) / 10.f;d.push_back(score);}sort(d.begin(), d.end(),greater<double>());           //降序排序//去除最高分和最低分d.pop_back();d.pop_front();double sum = accumulate(d.begin(), d.end(), 0.0f);double avg = sum / (double)d.size();return avg;
}//显示得分(1)
void Speechmanger::showscore()
{cout << "第一轮晋级决赛选手如下:" << endl;for (vector<int>::iterator it = v2.begin(); it != v2.end(); it++){cout << "选手编号:" << *it << "  姓名:" << this->m_s[*it].m_name << "  得分:"<< this->m_s[*it].m_score[0]<<endl;}cout << endl;system("pause");system("cls");this->showmenu();
}//显示决赛获奖名单
void Speechmanger::showhonor()
{cout << "第二轮决赛获奖选手如下:" << endl;for (vector<int>::iterator it = v3.begin(); it != v3.end(); it++){cout << "选手编号:" << *it << "  姓名:" << this->m_s[*it].m_name << "  得分:"<< this->m_s[*it].m_score[this->index-1] << endl;}cout << endl;system("pause");system("cls");this->showmenu();
}//保存本届决赛记录
void Speechmanger::saverecord()
{ofstream ofs;ofs.open("speech.csv",ios::out | ios::app);   //以追加方式写文件for (vector<int>::iterator it = v3.begin(); it != v3.end(); it++){ofs << *it << "," << this->m_s[*it].m_name << "," << this->m_s[*it].m_score[1] <<",";}ofs<<endl;ofs.close();cout << "记录保存完毕" << endl;this->fileempty = false;
}//读取比赛记录
void Speechmanger::loadrecord()
{ifstream ifs("speech.csv", ios::in);        //读文件//文件不存在if(!ifs.is_open()){this->fileempty = true;return;}//文件存在但被清空char ch;ifs >> ch;if (ifs.eof()){this->fileempty = true;ifs.close();return;}//文件不为空this->fileempty = false;ifs.putback(ch);string data;int num = 0;while (ifs >> data){vector<string> v;int pos = -1;          //查找","的位置int start = 0;         //开始查找的位置while (true){pos = data.find(",", start);if (pos == -1){//没有找到的情况break;}string temp = data.substr(start, pos - start);v.push_back(temp);start = pos + 1;}this->m_record.insert(make_pair(num, v));num++;}ifs.close();
}//显示往届记录
void Speechmanger::showrecord()
{if (this->fileempty){cout << "文件为空或记录不存在!" << endl;}else {for (int i = 0; i < this->m_record.size(); i++){cout << "第" << i + 1 << "届信息:" << endl;cout << "冠军编号:" << this->m_record[i][0] << " 冠军姓名:" << this->m_record[i][1] << " 冠军得分:" << this->m_record[i][2] << endl;cout << "亚军编号:" << this->m_record[i][3] << " 亚军姓名:" << this->m_record[i][4] << " 亚军得分:" << this->m_record[i][5] << endl;cout << "季军编号:" << this->m_record[i][6] << " 季军姓名:" << this->m_record[i][7] << " 季军得分:" << this->m_record[i][8] << endl;}}system("pause");system("cls");
}//清空文件
void Speechmanger::clearfile()
{cout << "是否确定清空文件?" << endl;cout << "1、是         2、否" << endl;int select = 0;cin >> select;if (select == 1){ofstream ofs("speech.csv", ios::trunc);ofs.close();this->initspeech();this->creatspeaker();this->loadrecord();cout << "清空成功!" << endl;}system("pause");system("cls");
}

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

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

相关文章

Golang中init()函数初始化顺序

Q24.init()函数初始化顺序 init() 函数是用于程序执行前做包的初始化的函数&#xff0c;比如初始化包里的变量等一个包可以出线多个 init() 函数,一个源文件也可以包含多个 init() 函数同一个包中多个 init() 函数的执行顺序没有明确定义&#xff0c;但是不同包的init函数是根…

2 Java的基本程序设计结构(基本语法1)

文章目录 前言一、数据类型0 与Python的一些区别1 基本数据类型(1)整型(2)浮点数类型(3)字符(char)类型(4)布尔类型(true、false)(5)代码示例2 引用数据类型二、变量与常量1 变量2 常量(*)3 枚举类型变量(*)4 变量的作用域三、变量和类起名规范1 硬性要求(变量…

线程的复习

目录 大纲Java中的线程概念创建线程的方法线程的生命周期线程的同步和通信线程的优先级和调度线程的中断 案例 大纲 Java中的线程概念 在Java中&#xff0c;线程是操作系统能够进行运算调度的最小单位&#xff0c;它被包含在进程之中&#xff0c;是进程中实际运作的部分。一个…

网络配置命令

文章目录 一、查看网络接口信息 ifconfig1.1 网络接口名称1.2 使用 ifconfig 查看网络接口信息1.2.1 输出示例1.2.2 输出解释 1.3 查看特定网络接口信息1.3.1 输出示例 1.4 查看所有网络接口信息1.5 特殊网络接口 二、修改网络配置文件2.1 配置文件示例2.2 使配置生效2.3 关闭 …

图——图的遍历(DFS与BFS)

前面的文章中我们学习了图的基本概念和存储结构&#xff0c;大家可以通过下面的链接学习&#xff1a; 图的定义和基本术语 图的类型定义和存储结构 这篇文章就来学习一下图的重要章节——图的遍历。 目录 一&#xff0c;图的遍历定义&#xff1a; 二&#xff0c;深度优先…

应用实践之基于MindNLP+MusicGen生成自己的个性化音乐

前言 MusicGen是基于单个语言模型&#xff08;LM&#xff09;的音乐生成模型&#xff0c;使用文本描述或音频提示生成高质量的音乐样本。它基于Transformer结构&#xff0c;包括文本编码器模型和音频压缩模型&#xff0c;以及一个解码器来预测离散的隐形状态音频token。与传统…

uni-data-select 插件配置接收字段,更改默认的text,value

当后台返回的数据源格式不是如下value,text字段时&#xff0c;需要自定义字段配置 range: [{ value: 0, text: "篮球" },{ value: 1, text: "足球" },{ value: 2, text: "游泳" },], 思路有两个&#xff0c; 思路一&#xff1a;前端遍历更改为…

PE文件(十一)移动导出表和重定位表

移动表的原因 一个PE文件中有很多节&#xff0c;每个节都存储不同的数据。而PE文件中的各种表也都分散存储在这些节当中。此时各种表的信息与程序的代码和数据相互混合在一起&#xff0c;如果我们直接对整个程序进行加密&#xff0c;那系统在初始化程序时就会出问题。比如&…

Linux系统之部署盖楼小游戏

Linux系统之部署盖楼小游戏 一、小游戏介绍1.1 小游戏简介1.2 小游戏玩法基本介绍1.3 项目预览二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍2.3 版本要求三、检查本地环境3.1 检查本地操作系统版本3.2 检查系统内核版本四、安装node.js4.1 安装nvm4.2 查看nvm版本4.3 安装…

DHCP原理及配置

目录 一、DHCP原理 DHCP介绍 DHCP工作原理 DHCP分配方式 工作原理 DHCP重新登录 DHCP优点 二、DHCP配置 一、DHCP原理 1 DHCP介绍 大家都知道&#xff0c;现在出门很多地方基本上都有WIFI&#xff0c;那么有没有想过这样一个问题&#xff0c;平时在家里都是“固定”的…

【总结】实际业务场景中锁、事务、异常如何考虑使用?

文章目录 锁处理目的&#xff1a;考虑锁控制思路&#xff1a;生命周期接口并发控制解决方案&#xff1a;测试锁是否生效&#xff1a;模拟多线程并发场景的2种方式&#xff1a; 事务处理目的&#xff1a;考虑事务控制思路&#xff1a;解决方案&#xff1a; 总结 锁处理 目的&am…

利用AI辅助制作ppt封面

如何利用AI辅助制作一个炫酷的PPT封面 标题使用镂空字背景替换为动态视频 标题使用镂空字 1.首先&#xff0c;新建一个空白的ppt页面&#xff0c;插入一张你认为符合主题的图片&#xff0c;占满整个可视页面。 2.其次&#xff0c;插入一个矩形&#xff0c;右键选择设置形状格式…

C++ 入门12:模板(Template)

往期回顾&#xff1a; C 入门09&#xff1a;友元函数和友元类-CSDN博客 C 入门10&#xff1a;继承和派生类-CSDN博客 C 入门11&#xff1a;虚函数和多态-CSDN博客 C 入门12&#xff1a;模板&#xff08;Template&#xff09; 一、前言 在前面文章的学习中&#xff0c;我们掌握…

Centos---命令详解 vi 系统服务 网络

目录 一、CentOS vi命令详解 二、CentOS系统服务命令 三、CentOS权限管理命令&#xff1a; 四、CentOS网络管理命令介绍&#xff1a; 一、CentOS vi命令详解 Vi是一款强大的文本编辑器&#xff0c;在CentOS中广泛使用。以下是Vi编辑器的一些常用命令&#xff1a; 1. 打开…

北京交通大学《深度学习》专业课,实验2-前馈神经网络

1. 源代码 见资源“北京交通大学《深度学习》专业课&#xff0c;实验2-前馈神经网络” 2. 实验内容 &#xff08;1&#xff09;手动实现前馈神经网络解决上述回归、二分类、多分类任务 分析实验结果并绘制训练集和测试集的loss曲线 &#xff08;2&#xff09;利用to…

08-8.3.1 冒泡排序

&#x1f44b; Hi, I’m Beast Cheng &#x1f440; I’m interested in photography, hiking, landscape… &#x1f331; I’m currently learning python, javascript, kotlin… &#x1f4eb; How to reach me --> 458290771qq.com 喜欢《数据结构》部分笔记的小伙伴可以…

keepalive:

keepalive&#xff1a; 调度器的高可用 vip地址在主备之间的切换&#xff0c;主在工作时&#xff0c;vip地址只在主上&#xff0c;主停止工作&#xff0c;vip漂移到备服务器。 在主备的优先级不变的情况下&#xff0c;主恢复工作&#xff0c;vip会飘回到主服务器。 1、配优…

企业网络运维-给华为交换机配置sftp,浏览交换机文件并下载上传

文章目录 需求实验开户stelnet权限已完成stelnet账号下的sftp配置使用xshell-sftp访问 需求 浏览交换机文件并下载上传 实验 开户stelnet权限 参考https://blog.csdn.net/xzzteach/article/details/140419150 已完成stelnet账号下的sftp配置 服务类型all包括stelnet和sf…

过滤器(Filter)和拦截器(Interceptor)的区别

过滤器&#xff08;Filter&#xff09;和拦截器&#xff08;Interceptor&#xff09;都是用于在请求处理过程中执行额外逻辑的机制&#xff0c;但它们在实现和使用上有一些重要的区别&#xff1a; 过滤器&#xff08;Filter&#xff09; 定义和用途&#xff1a; 过滤器主要用于…

强化学习编程实战-5 基于时间差分的方法

第4章中&#xff0c;当模型未知时&#xff0c;由于状态转移概率P未知&#xff0c;动态规划中值函数的评估方法不再适用&#xff0c;用蒙特卡洛的方法聘雇值函数。 在蒙特卡洛方法评估值函数时&#xff0c;需要采样一整条轨迹&#xff0c;即需要从初始状态s0到终止状态的整个序列…