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模式可以划分为磁盘…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...

dedecms 织梦自定义表单留言增加ajax验证码功能
增加ajax功能模块,用户不点击提交按钮,只要输入框失去焦点,就会提前提示验证码是否正确。 一,模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...
【论文笔记】若干矿井粉尘检测算法概述
总的来说,传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度,通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
鱼香ros docker配置镜像报错:https://registry-1.docker.io/v2/
使用鱼香ros一件安装docker时的https://registry-1.docker.io/v2/问题 一键安装指令 wget http://fishros.com/install -O fishros && . fishros出现问题:docker pull 失败 网络不同,需要使用镜像源 按照如下步骤操作 sudo vi /etc/docker/dae…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南
🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

Linux 内存管理实战精讲:核心原理与面试常考点全解析
Linux 内存管理实战精讲:核心原理与面试常考点全解析 Linux 内核内存管理是系统设计中最复杂但也最核心的模块之一。它不仅支撑着虚拟内存机制、物理内存分配、进程隔离与资源复用,还直接决定系统运行的性能与稳定性。无论你是嵌入式开发者、内核调试工…...

DingDing机器人群消息推送
文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人,点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置,详见说明文档 成功后,记录Webhook 2 API文档说明 点击设置说明 查看自…...