C++演讲比赛流程管理系统_黑马
学校演讲比赛,12人,两轮,第一轮淘汰赛,第二轮决赛
选手编号 [ 10001 - 10012 ]
分组比赛 每组6人
10个评委 去除最高分 最低分,求平均分 为该轮成绩
每组淘汰后三名,前三名晋级决赛
决赛 前三名胜出
每轮 比赛过后 要显示晋级选手信息
(点击此处-下载源代码)
- 开始演讲比赛:完成 一整届比赛流程,每阶段给用户提示,任意键进入下一阶段
- 查看往届记录:查看比赛前三名结果,每次比赛都记录到文件中,用*.csv存储
- 清空记录:将文件中数据清空
- 退出程序:将文件中数据清空
speechManager.h
#pragma once
#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
#include <deque>
#include <functional>
#include <numeric>
#include <fstream>
#include"speaker.h"
using namespace std;
/*1.提供惨淡界面与用户交互2.对演讲比赛流程进行控制3.与文件读写交互
*/
class SpeechManager
{
public:vector<int> v1; //比赛选手 12人 第一轮vector<int> v2; //第一轮晋级 6人vector<int> vVectory; //晋级 3人map<int, Speaker> m_Speaker;//编号,具体选手 map容器int m_Index; //比赛轮数map<int, vector<string>> m_Record; //存放往届记录bool fileIsEmpty; //file是否为空SpeechManager();void show_Menu();void initSpeech(); //初始化容器属性void createSpeaker(); //创建12名选手void exit_Sys_0();void speechDraw(); //抽签void speechContest(); //竞赛void showScore(); //显示得分void saveRecord(); //Save 记录void startSpeech_1(); //开始整个流程void loadRecode(); //读取往届记录void showRecode_2(); //查看记录void clearRecode_3();~SpeechManager();
};class printVectorInt{
public:void operator()(int val) {cout << val << " ; ";}
};
speaker.h
#pragma once
#include <iostream>
using namespace std;class Speaker
{
public:void setSpeakerName(string name);void setSpeakerS1(double a);void setSpeakerS2(double a);string getName();double* getScore();private:string m_Name;double* m_Score = new double[2]; //两轮得分,数组
};
SpeechCompetition_Sys.cpp
#include<iostream>
#include<string>
#include <ctime>
#include"speechManager.h"
#include"speaker.h"using namespace std;int main() {srand((unsigned int)time(NULL));SpeechManager sm;
//test://for (map<int, Speaker>::iterator it = sm.m_Speaker.begin(); it != sm.m_Speaker.end(); ++it) {// double* arr = it->second.getScore();// cout << "Test ID: " << it->first// << "\t Name: " << it->second.getName()// << "\t Score: " << arr[0] << endl;//}int inputChoice = -1;while (1) {sm.show_Menu();cout << "Please input Your Choice :" << endl;cin >> inputChoice;switch (inputChoice) {case 1: //开始比赛sm.startSpeech_1();break;case 2: //往届记录sm.showRecode_2();break;case 3: //清空记录sm.clearRecode_3();break;case 0: //退出sm.exit_Sys_0();break;default:system("cls");break;}}system("pause");return 0;
}
speaker.cpp
#include"speaker.h"
#include<string>
using namespace std;void Speaker::setSpeakerName(string name) {this->m_Name = name;
}void Speaker::setSpeakerS1(double a) {this->m_Score[0] = a;
}void Speaker::setSpeakerS2(double a) {this->m_Score[1] = a;
}string Speaker::getName() {return m_Name;
}
double* Speaker::getScore() {return this->m_Score;
/*Speaker s;string name = "GodOuO";double score[2] = { 12,34.5 };s.setSpeaker(name, score);double* arr = s.getScore();cout << arr[0] << arr[1];delete[] arr;
*/
}
speechManager.cpp
#include"speechManager.h"SpeechManager::SpeechManager()
{this->initSpeech(); //初始化容器属性this->createSpeaker(); //创建12名选手this->loadRecode(); //加载数据
}void SpeechManager::show_Menu() {cout << "*******************************" << endl<< "*****SpeechCompetition_Sys*****" << endl<< "**********#1.Start **********" << endl<< "**********#2.Histry **********" << endl<< "**********#3.Clean **********" << endl<< "**********#0.Quit **********" << endl << endl;
}void SpeechManager::exit_Sys_0() {cout << "Bye Bye !!!" << endl;system("pause");exit(0);
}void SpeechManager::initSpeech() {//容器置空this->v1.clear();this->v2.clear();this->vVectory.clear();this->m_Speaker.clear();//index置空this->m_Index = 1;this->m_Speaker.clear();
}void SpeechManager::createSpeaker() {string nameSpace = "ABCDEFGHIJKL";for (int i = 0; i < nameSpace.length(); ++i){string name = "Name";name += nameSpace[i];Speaker s;s.setSpeakerName(name);s.setSpeakerS1(0.0);s.setSpeakerS2(0.0);this->v1.push_back(i + 10001); //选手编号 存入v1this->m_Speaker.insert(make_pair(i + 10001, s));//选手编号 和对应选手 存入map}
}void SpeechManager::speechDraw() {cout << "The No.(" << this->m_Index << ") Round's Player is Drawing..." << endl<< "-----------------------------------------------------" << endl<< "The Order is :" << endl;if (1 == this->m_Index) { //Round 1random_shuffle(v1.begin(),v1.end());for_each(v1.begin(), v1.end(), printVectorInt());}else if (2 == this->m_Index) { //Round 2random_shuffle(v2.begin(), v2.end());for_each(v2.begin(), v2.end(), printVectorInt());}cout <<endl<< "-----------------------------------------------------" << endl;system("pause");cout << endl;
}void SpeechManager::speechContest() {cout << "The No.(" << this->m_Index << ") Round's Contest is Fighting..." << endl<< "-----------------------------------------------------" << endl;vector<int> v_Player; //比赛选手容器multimap<double, int, greater<double>> groupScore; //准备临时容器,存放小组成绩int num = 0; //记录人员个数 6人一组if (1 == this->m_Index) {v_Player = this->v1;}else if (2 == this->m_Index) {v_Player = this->v2;}for (vector<int>::iterator it= v_Player.begin(); it != v_Player.end(); ++it){ //遍历所有选手deque<double> d; //评委打分++num; //统计人数for (int i = 0; i < 10; ++i){double score = (rand() % 401 + 600) / 10.f; //(600-1000) /10.f//test:// cout<<"Test:"<<endl;//cout << score << " ; ";d.push_back(score);}//cout << endl;sort(d.begin(), d.end(), greater<double>()); //倒叙排序d.pop_front(); //del Topd.pop_back(); //del Lastdouble sum = accumulate(d.begin(), d.end(), 0.0f); //起始累加值 0.0f小数double avg = sum / (double)d.size(); //平均分if (1 == m_Index)this->m_Speaker[*it].setSpeakerS1(avg); //平均分 存入 map容器else if(2 == m_Index)this->m_Speaker[*it].setSpeakerS2(avg); //平均分 存入 map容器groupScore.insert(make_pair(avg, *it)); //key =平均成绩,value =IDif (0 == num % 6) { //每六个人 取前三cout << "No.<" << num / 6 << "> group‘s Contest List: " << endl<< "-----------------------------------------------------" << endl;for (multimap<double,int,greater<double>>::iterator it = groupScore.begin(); it != groupScore.end(); ++it){double* arr = this->m_Speaker[it->second].getScore();cout << "ID: " << it->second<< "\tName: " << this->m_Speaker[it->second].getName()<< "\tScore: " << arr[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 (1 == this->m_Index)this->v2.push_back((*it).second);else this->vVectory.push_back((*it).second);}groupScore.clear(); //del 缓存 组成绩cout << endl;}/*cout << "Test:" << endl;double* arr = this->m_Speaker[*it].getScore();cout << "ID: " << *it<< "\tName: " << this->m_Speaker[*it].getName()<< "\tScore: " << arr[0];*/} cout << "No.(" << this->m_Index << ") group‘s Contest Done!!! " << endl;system("pause");cout << endl;
}void SpeechManager::showScore() {cout << "The No.(" << this->m_Index << ") Round's Winner List:" << endl<< "-----------------------------------------------------" << endl;vector<int> v;if (1 == this->m_Index){v = v2;}else if (2 == this->m_Index) {v = vVectory;}for (vector<int>::iterator it = v.begin(); it!= v.end(); ++it){double* arr = this->m_Speaker[*it].getScore();cout << "ID: " << *it<< "\tName: " << this->m_Speaker[*it].getName()<< "\tScore: " << arr[this->m_Index - 1] << endl;}cout << endl;system("pause");system("cls");this->show_Menu();
}void SpeechManager::saveRecord() {ofstream ofs;ofs.open("speech.csv",ios::out | ios::app); //追加 写入for (vector<int>::iterator it = vVectory.begin(); it != vVectory.end(); ++it) //数据写入文件{double* arr = this->m_Speaker[*it].getScore(); //冠亚季三人ofs << *it << "," << arr[1] << ",";}ofs << endl;ofs.close();this->fileIsEmpty = false;cout << "Save it!!!" << endl;
}void SpeechManager::startSpeech_1(){//第一轮比赛:1.抽签;2.比赛;3.显示结果this->speechDraw();this->speechContest();this->showScore();//第二轮比赛:1.抽签;2.比赛;3.显示结果++m_Index;this->speechDraw();this->speechContest();this->showScore();//保存分数到文件this->saveRecord();//重置比赛,获取记录this->initSpeech(); //初始化容器属性this->createSpeaker(); //创建12名选手this->loadRecode(); //加载数据cout << endl << "This Round is Finished!!!" << endl;system("pause");system("cls");
}void SpeechManager::showRecode_2() {if (this->fileIsEmpty){cout << "File is Empty!!!" << endl;}else {for (int i = 0; i < this->m_Record.size(); ++i){cout << " NO.(" << i + 1 << ") Round Champion's ID: " << this->m_Record[i][0]<< "\tScore: " << this->m_Record[i][1] << endl;cout << " NO.(" << i + 1 << ") Round <No.2>'s ID: " << this->m_Record[i][2]<< "\tScore: " << this->m_Record[i][3] << endl;cout << " NO.(" << i + 1 << ") Round <No.3>'s ID: " << this->m_Record[i][4]<< "\tScore: " << this->m_Record[i][5] << endl;}}system("pause");system("cls");
}void SpeechManager::loadRecode() {ifstream ifs("speech.csv", ios::in);if (!ifs.is_open()) //文件不存在{this->fileIsEmpty = true;//cout << "File is NOT Exist !!!" << endl;ifs.close();return;}//文件清空char c;ifs >> c;if (ifs.eof()) {this->fileIsEmpty = true;//cout << "File is Empty !!!" << endl;ifs.close();return;}this->fileIsEmpty = false;ifs.putback(c); //将上文读取单个字符 存回string data; int index = 0; //第几届while (ifs >> data) {//test://cout << data << endl;int loc = -1; //查到’,‘ locint start = 0;vector<string> vtemp; //存放 6个 string 字符串while (1){loc = data.find(",", start);if (-1 == loc) { //未找到 ’,‘break;}string temp = data.substr(start, loc - start);//test://cout << temp << endl;vtemp.push_back(temp);start = loc + 1;}this->m_Record.insert(make_pair(index, vtemp));++index;}ifs.close();// test:// for (map<int,vector<string>>::iterator it = this->m_Record.begin(); it != this->m_Record.end() ; ++it)//{// cout << it->first// << " Winner ID: " << it->second[0]// << "\tScore: " << it->second[1] << endl;//}}void SpeechManager::clearRecode_3(){cout << endl << "Sure ?" << endl << "1.Yes" << endl << "2.No" << endl;int select = 0;cin >> select;if (1 == select) {//ios::trunc 如果文件存在,删除文件 重新创建ofstream ofs("speech.csv", ios::trunc);ofs.close();//初始化this->initSpeech(); //初始化容器属性this->createSpeaker(); //创建12名选手this->loadRecode(); //加载数据cout << "Clean Done!" << endl;}system("pause");system("cls");
}SpeechManager::~SpeechManager()
{
}
相关文章:

C++演讲比赛流程管理系统_黑马
任务 学校演讲比赛,12人,两轮,第一轮淘汰赛,第二轮决赛 选手编号 [ 10001 - 10012 ] 分组比赛 每组6人 10个评委 去除最高分 最低分,求平均分 为该轮成绩 每组淘汰后三名,前三名晋级决赛 决赛 前三名胜出 …...

谈谈低代码的安全问题,一文全给你解决喽
低代码是一种软件开发方法,通过使用图形化用户界面和可视化建模工具,以及自动生成代码的技术,使得开发人员可以更快速地构建和发布应用程序。 作为近些年软件开发市场热门之一,市面上也涌现了许多低代码产品,诸如简道云…...

[数据结构]二叉树OJ(leetcode)
目录 二叉树OJ(leetcode)训练习题:: 1.单值二叉树 2.检查两棵树是否相同 3.二叉树的前序遍历 4.另一棵树的子树 5.二叉树的构建及遍历 6.二叉树的销毁 7.判断二叉树是否是完全二叉树 二叉树OJ(leetcode)训练习题:: 1.单值二叉…...

flutter 输入时插入分隔符
每四位插入一个分隔符import package:flutter/services.dart;class DividerInputFormatter extends TextInputFormatter {final int rear; //第一个分割位数,后面分割位,,数final String pattern; //分割符DividerInputFormatter({this.rear 4, this.pattern });overrideTex…...

静态版通讯录——“C”
各位CSDN的uu你们好呀,之前小雅兰学过了一些结构体、枚举、联合的知识,现在,小雅兰把这些知识实践一下,那么,就让我们进入通讯录的世界吧 实现一个通讯录: 可以存放100个人的信息每个人的信息:名…...
前端基础开发环境搭建工具等
一、基本开发环境(软件)安装1、Vscode(代码编辑器)官网下载网址:https://code.visualstudio.com/2、nvm(node多版本管理器,每个node版本都有对应的npm版本)安装包下载地址࿱…...

华为OD机试题【IPv4 地址转换成整数】用 Java 解 | 含解题说明
华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南华为od机试,独家整理 已参加机试人员的实战技巧华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典本篇题目:IPv4 地址转换成整数 题目 存在…...

[数据结构]排序算法
目录 常用排序算法的实现:: 1.排序的概念及其运用 2.插入排序 3.希尔排序 4.选择排序 5.冒泡排序 6.堆排序 7.快速排序 8.归并排序 9.排序算法复杂度及稳定性分析 10.排序选择题练习 常用排序算法的实现:: 1.排序的概念及其运用…...

不愧是2023年就业最难的一年,还好有车企顶着~
就业龙卷风已经来临,以前都说找不到好的工作就去送外卖,但如今外卖骑手行业都已经接近饱和状态了,而且骑手们的学历也不低,本科学历都快达到了30%了,今年可以说是最难找到工作的一年。 像Android 开发行业原本就属于在…...

C/C++之while(do-while)详细讲解
目录 while循环有两个重要组成部分: while 是一个预测试循环 无限循环 do-while 循环 while循环有两个重要组成部分: 进行 true 值或 false 值判断的表达式;只要表达式为 true 就重复执行的语句或块;图 1 显示了 while 循环的…...

SpringCloud学习笔记(一)认识微服务
一、微服务技术栈 二、单体架构和分布式架构的区别 1、单体架构: 将业务的所有功能集中在一个项目中开发,打成一个包进行部署 优点:架构简单,部署成本低缺点:耦合度高 2、分布式架构: 根据业务功能对系统…...

Unity中使用WebSocket (ws://)的方法
WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。 WebSocket与http 其…...
米哈游春招算法岗-2023.03.19-第一题-交换字符-简单题
交换字符Problem Description 米小游拿到了一个仅由小写字母组成的字符串,她准备进行恰好一次操作:交换两个相邻字母,在操作结束后使得字符串的字典序尽可能大。 请你输出最终生成的字符串。 input 一个仅由小写字母组成的字符串,…...

能把爬虫讲的这么透彻的,没有20年功夫还真不行【0基础也能看懂】
前言 可以说很多人学编程,不玩点爬虫确实少了很多意思,不管是业余、接私活还是职业爬虫,爬虫世界确实挺精彩的。 今天来给大家浅谈一下爬虫,目的是让准备学爬虫或者刚开始起步的小伙伴们,对爬虫有一个更深更全的认知…...

springcloud学习总结
springcloud 构建微服务项目步骤 导入依赖编写配置文件开启这个功能 Enablexxx配置类 于2023年2月24日下午17点38分开始学习于2023年3月17日晚上20点26分学完总结代码地址:https://gitee.com/liang-weihao/StudySpringcloud学习笔记地址:https://www.…...

2022年亏损超10亿,告别野蛮成长的众安在线急需新“引擎”
2023年3月21日,众安在线披露了2022年财报,营收233.52亿元,同比增长6.44%;净亏损16.33亿元,去年同期净利润为11.6亿元,同比由盈转亏。 尽管众安在线再次身陷亏损的泥潭,但投资者却没有选择逃离。…...

ChatGPT文心一言逻辑大比拼(一)
❤️觉得内容不错的话,欢迎点赞收藏加关注😊😊😊,后续会继续输入更多优质内容❤️👉有问题欢迎大家加关注私戳或者评论(包括但不限于NLP算法相关,linux学习相关,读研读博…...

【机器学习面试总结】————特征工程
【机器学习面试总结】————特征工程一、特征归一化为什么需要对数值类型的特征做归一化?二、类别型特征在对数据进行预处理时,应该怎样处理类别型特征?三、高维组合特征的处理什么是组合特征?如何处理高维组合特征?四、组合特征怎样有效地找到组合特征?五、文本表示模型…...

如何将字符串反转?
参考答案 使用 StringBuilder 或 StringBuffer 的 reverse 方法,本质都调用了它们的父类 AbstractStringBuilder 的 reverse 方法实现。(JDK1.8)不考虑字符串中的字符是否是 Unicode 编码,自己实现。递归1. public AbstractStrin…...

Linux内核IO基础知识与概念
什么是 IO在计算机操作系统中,所谓的I/O就是 输入(Input)和输出(Output),也可以理解为读(Read)和写(Write),针对不同的对象,I/O模式可以划分为磁盘…...

springboot 百货中心供应链管理系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,百货中心供应链管理系统被用户普遍使用,为方…...
DeepSeek 赋能智慧能源:微电网优化调度的智能革新路径
目录 一、智慧能源微电网优化调度概述1.1 智慧能源微电网概念1.2 优化调度的重要性1.3 目前面临的挑战 二、DeepSeek 技术探秘2.1 DeepSeek 技术原理2.2 DeepSeek 独特优势2.3 DeepSeek 在 AI 领域地位 三、DeepSeek 在微电网优化调度中的应用剖析3.1 数据处理与分析3.2 预测与…...

Docker 运行 Kafka 带 SASL 认证教程
Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...
渲染学进阶内容——模型
最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...

React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...
python如何将word的doc另存为docx
将 DOCX 文件另存为 DOCX 格式(Python 实现) 在 Python 中,你可以使用 python-docx 库来操作 Word 文档。不过需要注意的是,.doc 是旧的 Word 格式,而 .docx 是新的基于 XML 的格式。python-docx 只能处理 .docx 格式…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...

在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
大学生职业发展与就业创业指导教学评价
这里是引用 作为软工2203/2204班的学生,我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要,而您认真负责的教学态度,让课程的每一部分都充满了实用价值。 尤其让我…...

Yolov8 目标检测蒸馏学习记录
yolov8系列模型蒸馏基本流程,代码下载:这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中,**知识蒸馏(Knowledge Distillation)**被广泛应用,作为提升模型…...