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;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

图形化编程:未来的编程范式

在科技飞速发展的今天&#xff0c;编程已经成为了我们生活中不可或缺的一部分。从手机应用开发&#xff0c;到人工智能&#xff0c;再到物联网&#xff0c;无一不涉及到编程。然而&#xff0c;传统的文本编程方式对于初学者来说&#xff0c;往往显得复杂且难以理解。这就使得图…

uniapp日期加减切换,点击切换

先上完成后的页面&#xff1a;当前年年份不显示&#xff0c;不然完整显示。 可以切换和自定义选择。 html:样式和图片自定义。 <view class"image-text_30"><image click"delMonth" :src"require(/static/home/zuo.png)" class"…

STL标准库与泛型编程(侯捷)笔记5

STL标准库与泛型编程&#xff08;侯捷&#xff09; 本文是学习笔记&#xff0c;仅供个人学习使用。如有侵权&#xff0c;请联系删除。 参考链接 Youbute: 侯捷-STL标准库与泛型编程 B站: 侯捷 - STL Github:STL源码剖析中源码 https://github.com/SilverMaple/STLSourceCo…

【JVM 基础】类字节码详解

JVM 基础 - 类字节码详解 多语言编译为字节码在JVM运行Java字节码文件Class文件的结构属性从一个例子开始反编译字节码文件字节码文件信息常量池方法表集合类名 再看两个示例分析try-catch-finallykotlin 函数扩展的实现 源代码通过编译器编译为字节码&#xff0c;再通过类加载…

安谋科技“周易”NPU与飞桨完成II级兼容性测试,助力实现多样化AI部署

近日&#xff0c;安谋科技&#xff08;中国&#xff09;有限公司&#xff08;以下简称“安谋科技”&#xff09;“周易”NPU系列IP与飞桨已完成II级兼容性测试&#xff0c;测试结果显示&#xff0c;双方兼容性表现良好&#xff0c;整体运行稳定。这是安谋科技加入“硬件生态共创…

SaaS 电商设计 (六) 实现 id 生成器本地化生产 (附源码)

一.背景 1.1 背景 业务背景: 目前梳理 SaaS 系统中存在以下几种 Id 生成的场景. 财务系统: 财务在生产财务单的时候,获取财务单 Id ,满足分布式场景下能够获取全局Id即可. 支付系统:订单系统在进行外部提单过程中,需要将生成的订单号与外部的支付平台做对接.在具体开发调试…

400μA低功率接地故障断路器控制芯片D4147,内置精密感应放大器与带隙基准,适用于GFCI和RCD

低功率接地故障断路器&#xff08;GFI&#xff09;控制芯片D4147主要用于三线制GFCI输出接口、GFCI芯片断路器、便携式GFCI线路等领域的产品&#xff0c;侦测并防护火线对地故障和零线对负载短路故障。 功能介绍 D4147为低功率接地故障断路器&#xff08;GFI&#xff09;控制…

Zookeeper 和 naocs的区别

Nacos 和 ZooKeeper 都是服务发现和配置管理的工具&#xff0c;它们的主要区别如下&#xff1a;功能特性&#xff1a;Nacos 比 ZooKeeper 更加强大&#xff0c;Nacos 支持服务发现、动态配置、流量管理、服务治理、分布式事务等功能&#xff0c;而 ZooKeeper 主要用于分布式协调…

RK3568驱动指南|第十篇 热插拔-第117章uevent_helper实验

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工艺&#xff0c;搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码&#xff0c;支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU&#xff0c;可用于轻量级人工…

python json模块

json是JavaScript对象表示法的缩写&#xff0c;是一种轻量级的数据交换格式&#xff0c;经常被用于Web应用程序中。python中的json库是用于解析和生成json数据格式的库。 import jsondata {"name": "张三","age": 18,"hobbies": [&q…

Unity报错:[SteamVR] Not Initialized (109)的解决方法

问题描述 使用HTC vive 头像进行SteamVR插件的示例场景进行测试&#xff0c;发现头显场景无法跳转到运行场景&#xff08;Unity 项目可以运行&#xff0c;仅出现警告&#xff09;。 具体如下&#xff1a; [SteamVR] Not Initialized (109) [SteamVR] Initialization failed…

python 基础知识点(蓝桥杯python科目个人复习计划20)

今日复习内容&#xff1a;基础算法中的选择排序/插入排序/快速排序/归并排序/桶排序 一.选择排序 1.算法步骤 从左往右找到最小的元素&#xff0c;放在起始位置重复上述步骤&#xff0c;依次找到第二&#xff0c;第三小的元素 2.具体描述 给定一个长度为n的列表&#xff0…

[VisualStudioCode]_[VSCODE]_[C/C++开发环境配置-问题解决和补充]

场景 在使用VSCode配置C的开发环境时《VisualStudioCode_C/C开发环境配置[1]》&#xff0c;编译时会发现找不到标准库的std::mutex和std::thread的声明&#xff0c;而这两个的头文件已经引入&#xff0c;什么情况&#xff1f; 无论如何MinGW都是Windows上验证开发C特性比较新的…

Python从入门到网络爬虫(控制语句详解)

前言 做任何事情都要遵循一定的原则。例如&#xff0c;到图书馆去借书&#xff0c;就需要有借书证&#xff0c;并且借书证不能过期&#xff0c;这两个条件缺一不可。程序设计亦是如此&#xff0c;需要使用流程控制实现与用户的交流&#xff0c;并根据用户需求决定程序“做什么…

运用AI搭建中间服务层(一)

知识点 适用于 AI 的 Visual Studio 工具 微软认知服务&#xff08;影像服务/实体搜索服务&#xff09;的使用 商业应用软件的架构设计 ASP.NET 核心 Web 应用程序 休息 应用程序接口 服务端的测试技术 软件工程中的需求演进处理 不断演进的应用场景 下面我们会用讲故…

PR-视频去水印

文章目录 前言PR-视频去水印实现示例 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不易啊^ _ ^。   而且听说点赞的人每天的运气都不会太差&#xff0c;实在白嫖的话&#xff0c;那欢迎常来啊!!! PR-视频…

Unity组件开发--短连接HTTP

1.网络请求管理器 using LitJson; using Cysharp.Threading.Tasks; using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.Networking; using UnityEngine.Events;using System.Web; using System.Text; using Sy…

企业的 Android 移动设备管理 (MDM) 解决方案

移动设备管理可帮助您在不影响最终用户体验的情况下&#xff0c;通过无线方式管理和保护组织的移动设备群&#xff0c;现代 MDM 解决方案还可以控制 App、内容和安全性&#xff0c;因此员工可以毫无顾虑地在托管设备上工作。移动设备管理软件可有效管理个人设备上的公司空间。M…

刷题第十五天-存在重复元素Ⅲ

存在重复元素Ⅲ 题目要求 解题思路 主要使用滑动窗口方法&#xff0c;让滑动窗口代销固定为t。 本题最大的难点在于快速地找到滑动窗口内的最大值和最小值&#xff0c;以及删除指定元素。 如果遍历求滑动窗口内的最大值和最小值&#xff0c;时间复杂度是O&#xff08;K&#…

自动化测试框架搭建全过程

前段时间写了一系列自动化测试相关的文章&#xff0c;当然更多的是方法和解决问题的思路角度去阐述我的一些观点。这篇文章来聊聊新手如何从零到一落地实践接口自动化测试。 为什么要做接口测试 测试理念的演变 早些时候&#xff0c;软件研发交付流程大多遵循V型或W型的瀑布模…