【C++】基于STL演讲比赛流程管理系统

2023-11-07 09:52

本文主要是介绍【C++】基于STL演讲比赛流程管理系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一、比赛规则
  • 二、比赛功能
  • 三、全部代码
      • 1. test.cpp
      • 2. Speecher.h
      • 3. SpeecherManager.h
      • 4. SpeecherManager.cpp


💙 本管理系统参考黑马C++课程B站课程指路,仅作参考与学习资料。
🧡 核心课程笔记 👉C++核心
🧡 提高课程笔记 👉C++提高

一、比赛规则

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

二、比赛功能

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

[ 注意 ]csv格式可以用excel或记事本方式打开。

三、全部代码

1. test.cpp

#include "Speecher.h"
#include "SpeechManager.h"
#include<iostream>
using namespace std;
int main()
{SpeechManager sm;sm.SpeechMeun();int choose = 0;srand((unsigned int)time(NULL));do{cout << "请输入:";cin >> choose;switch (choose){case 1:sm.StartSpeech();break;case 2:sm.ShowRecord();break;case 3:sm.ClearRecord();break;case 0:sm.ExitManager();break;default:cout << "输入有误,请重新输入" << endl;break;}} while (choose);return 0;
}

2. Speecher.h

#pragma once
#include<iostream>
#include<string>
using namespace std;
class Speecher
{
public:string name;double score[2];//两次分数:第一次为晋级分数,第二次为决赛分数
};

3. SpeecherManager.h

#pragma once
#include<iostream>
#include<string>
#include<vector>
#include<map>
#include <deque>
#include <algorithm>
#include <functional>
#include <numeric>
#include <fstream>
#include "Speecher.h"
using namespace std;
//演讲比赛管理类
class SpeechManager
{
public:SpeechManager();//构造~SpeechManager();//析构//菜单功能void SpeechMeun();//初始化void InitManager();//创建12位选手void CreatSpeaker();//开始比赛void StartSpeech(){//第一轮比赛//1.抽签this->SpeechDraw();//2.比赛this->SpeechContest();//3.公布晋级选手this->ShowScore();this->idex++;//1.抽签this->SpeechDraw();//2.比赛this->SpeechContest();//3.最终结果this->ShowScore();//4.最终结果保存在文件中this->SaveRecord();cout << "本届比赛完毕!" << endl;this->InitManager();this->CreatSpeaker();this->LoadRecord();}void SpeechDraw();//选手抽签void SpeechContest();//选手比赛void ShowScore();//晋级分数或决赛分数void SaveRecord();//保存决赛前三成绩void ShowRecord();//展示往届决赛成绩void LoadRecord();//读取往届成绩void ClearRecord();//清空数据void ExitManager();//退出vector<int> v1;//12个选手的编号vector<int> v2;//第一轮晋级选手的编号vector<int> victory;//胜利前三名选手的编号map<int, Speecher> m_speaker;//编号 和 对应的选手int idex;//比赛轮数bool FileIsEmpty;map<int, vector<string>> m_Record;//往届记录,包括:届数和每届冠军季军亚军
};

注意:在这里插入图片描述

4. SpeecherManager.cpp

#include "SpeechManager.h"
SpeechManager::SpeechManager()
{this->InitManager();this->CreatSpeaker();this->LoadRecord();
}
void SpeechManager::SpeechMeun()
{cout << "************************" << endl;cout << "*****1.开始演讲比赛*****" << endl;cout << "*****2.查看往届记录*****" << endl;cout << "*****3.清空比赛记录*****" << endl;cout << "*****0.  退出程序  *****" << endl;cout << "************************" << endl;
}
void SpeechManager::InitManager()
{this->v1.clear();this->v2.clear();this->victory.clear();this->m_speaker.clear();this->idex = 1;
}
void SpeechManager::CreatSpeaker()
{string name_seed = "ABCDEFGHIJKL";for (int i = 0; i < 12; i++){string name = "选手";name = name + name_seed[i];Speecher s;s.name = name;s.score[0] = 0;s.score[1] = 0;this->v1.push_back(i+1001);this->m_speaker.insert(make_pair(i + 1001, s));}}
void SpeechManager::SpeechDraw()
{cout << "第" << this->idex << "轮比赛" << endl;cout << "选手抽签结果:" << endl;if (this->idex == 1){random_shuffle(v1.begin(), v1.end());for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++)cout << *it << " ";}else{random_shuffle(v2.begin(), v2.end());for (vector<int>::iterator it = v2.begin(); it != v2.end(); it++)cout << *it << " ";}cout << endl;cout << "---------------------------------------------" << endl;
}
void SpeechManager::SpeechContest()
{multimap<double, int, greater<double>> gourp_temp;//临时小组 cout << "第" << this->idex << "轮比赛" << endl;vector<int> v_temp;if (this->idex == 1)v_temp = v1;elsev_temp = v2;int num = 0;for (vector<int>::iterator it = v_temp.begin(); it != v_temp.end(); it++){num++;deque<double> score;double each_score = 0.0;//十个评委打分for (int i = 0; i < 10; i++){each_score=(rand() % 401 + 600) / 10.f;score.push_back(each_score);}//去掉最高分与最低分 1.排序 2.pop首尾sort(score.begin(), score.end(), greater<double>());score.pop_back();score.pop_front();//求平均分double avg= accumulate(score.begin(), score.end(), 0)/ (double)score.size();//将分数放入map中this->m_speaker[*it].score[this->idex - 1] = avg;//分数和个人放在maltimap中gourp_temp.insert(make_pair(avg, *it));if (num % 6 == 0){//输出当前小组成绩cout << "第"<<num/6<<"组小组成绩:" << endl;for (multimap<double, int, greater<double>>::iterator it = gourp_temp.begin(); it != gourp_temp.end(); it++){cout << "编号:" << it->second << "  姓名: " << this->m_speaker[it->second].name<< "  成绩:" << m_speaker[it->second].score[this->idex - 1] << endl;}//取前三名int count = 0;for (multimap<double, int, greater<double>>::iterator it = gourp_temp.begin(); it != gourp_temp.end()&&count!=3; it++,count++){if (this->idex == 1){v2.push_back((*it).second);}else{victory.push_back((*it).second);}}gourp_temp.clear();}}cout << "----------第" << this->idex << "轮比赛结束-----------" << endl;
}
void SpeechManager::ShowScore()
{//如果是晋级if (this->idex == 1){cout << "晋级名单:" << endl;for (vector<int>::iterator it = v2.begin(); it != v2.end(); it++)cout << "编号:" << *it << "姓名:" << m_speaker[*it].name << "成绩:" << m_speaker[*it].score[this->idex - 1] << endl;}//如果是决赛else{cout << "最终结果:" << endl;for (vector<int>::iterator it = victory.begin(); it != victory.end(); it++)cout << "编号:" << *it << "姓名:" << m_speaker[*it].name << "成绩:" << m_speaker[*it].score[this->idex - 1] << endl;}
}
void SpeechManager::SaveRecord()
{ofstream ofs;ofs.open("speech.csv", ios::out | ios::app);//写文件,用追加(app)方式//将每个选手信息,写入到文件中for (vector<int>::iterator it = victory.begin(); it != victory.end(); it++){//csv格式需要用,分割ofs << *it << "," << this->m_speaker[*it].score[1] << ",";}ofs << endl;ofs.close();//关闭文件this->FileIsEmpty = false;cout << "记录已经保存" << endl;
}
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;}}
}
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;return;}//文件不为空this->FileIsEmpty = false;ifs.putback(ch); //将上面读取的单个字符放回来string data;int index = 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(index, v));index++;}ifs.close();
}
void SpeechManager::ClearRecord()
{cout << "是否确定清空文件" << endl;cout << "1.是" << endl;cout << "2.否" << endl;int select = 0;cin >> select;if (select == 1){ofstream ofs("speech.csv", ios::trunc);ofs.close();this->InitManager();this->CreatSpeaker();this->LoadRecord();cout << "清空成功" << endl;}else{}
}
void SpeechManager::ExitManager()
{cout << "欢迎下次使用" << endl;exit(0);
}
SpeechManager::~SpeechManager()
{}

这篇关于【C++】基于STL演讲比赛流程管理系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/362838

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于