STL项目-学校演讲比赛
// 学校演讲比赛.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
// #include "pch.h"
#include <iostream>
#include "string"
#include "vector"
#include "algorithm"
#include "functional"
#include "list"
#include "iterator"
#include "map"
#include "deque"
#include "numeric"
using namespace std; class speaker
{
public:
string m_name;
int m_score[]; }; int GenSpeaker(map<int, speaker> &mapSpeaker, vector<int> &v)
{
string str = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
random_shuffle(str.begin(), str.end()); for (int i = ; i < ; i++)
{
speaker tmp;
tmp.m_name = "选手";
tmp.m_name += str[i];
mapSpeaker.insert(pair<int, speaker>( + i, tmp));
} for (int i = ; i < ; i++)
{
v.push_back( + i);
} return ;
} //选手抽签
int speech_contest_draw(vector<int> &v)
{
random_shuffle(v.begin(), v.end());
return ;
} //选手比赛
int speech_contest(int index, map<int, speaker> &mapSpeaker,vector<int> &v1, vector<int> &v2)
{
//小组的比赛得分 记录下来;求出前三名 和 后三名
multimap<int, int, greater<int>> multmapGroup;
int tmpCount = ;
for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++)
{
tmpCount++;
//打分
{
deque<int> dscore;
for (int j = ; j < ; j++)
{
int score = + rand() % ;
dscore.push_back(score);
}
sort(dscore.begin(), dscore.end());
dscore.pop_back();
dscore.pop_front();
//求平均分
int scoresumm = accumulate(dscore.begin(), dscore.end(), );
int scoreavg = scoresumm / dscore.size();
mapSpeaker[*it].m_score[index] = scoreavg;//选手得分存入容器中
multmapGroup.insert(pair<int, int>(scoreavg, *it));
} //处理分组
if (tmpCount % == )
{
cout << "小组的比赛成绩:" << endl;
for (multimap<int, int, greater<int>>::iterator mit = multmapGroup.begin(); mit != multmapGroup.end(); mit++)
{
//编号 姓名 得分
cout << mit->second << "\t" << mapSpeaker[mit->second].m_name << "\t" << mit->first <<endl;
}
//前三名晋级
while (multmapGroup.size() > )
{
multimap<int, int, greater<int>>::iterator it1 = multmapGroup.begin();
v2.push_back(it1->second);//把前三名放到晋级名单中
multmapGroup.erase(it1);
}
multmapGroup.clear();//清空本小组比赛成绩
} }
return ;
} //查看比赛结果
int speech_contest_print(int index, map<int, speaker> &mapSpeaker, vector<int> &v)
{
printf("第%d轮,晋级名单\n", index +);
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << "参赛编号:" << *it << "\t" << mapSpeaker[*it].m_name << "\t"<< mapSpeaker[*it].m_score[index] <<endl;
}
return ;
}
int main()
{
//1.容器的设计
map<int, speaker> mapSpeaker;
vector<int> v1;//第1轮比赛 名单
vector<int> v2;//第2轮比赛 名单
vector<int> v3;//第3轮比赛 名单
vector<int> v4;//最后前三名 名单 //产生选手 得到第1轮选手比赛名单
GenSpeaker(mapSpeaker, v1); //第1轮:选手抽签、选手比赛、查看比赛结果
cout << "\n\n\n任意键,开始第1轮比赛..." << endl;
cin.get();
speech_contest_draw(v1);
speech_contest(, mapSpeaker, v1, v2);
speech_contest_print(, mapSpeaker, v2); //第2轮:选手抽签、选手比赛、查看比赛结果
cout << "\n\n\n任意键,开始第2轮比赛..." << endl;
cin.get();
speech_contest_draw(v2);
speech_contest(, mapSpeaker, v2, v3);
speech_contest_print(, mapSpeaker, v3); //第3轮:选手抽签、选手比赛、查看比赛结果
cout << "\n\n\n任意键,开始决赛..." << endl;
cin.get();
speech_contest_draw(v3);
speech_contest(, mapSpeaker, v3, v4);
speech_contest_print(, mapSpeaker, v4); std::cout << "Hello World!\n";
}
STL项目-学校演讲比赛的更多相关文章
- C++ 基于STL的演讲比赛流程管理系统(sort算法+小型算法(accumulate)+内建函数对象+string字符串拼接+字符串截取+多个容器基础操作+与用户交互+文件的读写+保存+重建+整体文件数据的清空)
1 /* 2 比赛规则: 3 学校举行一演讲比赛,共12个人参加,比赛两轮,第一轮为淘汰赛 第二轮为决赛 4 每名选手都有对应的编号:如10001~10012 5 比赛方式:分组比赛 每组6人 6 第 ...
- 2018 Unite大会——《使用UPA工具优化项目》演讲实录
2018年5月11日至13日,腾讯WeTest与Unity联合打造的移动游戏性能分析工具(Unity Performance Analysis,以下称为UPA)正式亮相2018 Unite大会,为Un ...
- 项目ppt演讲与阶段性总结
☆车老师讲解PPT项目: 1.汉企0410天启网络公司 2.Ppt--画龙点睛 3.项目制作背景-->点到人心上,别一堆文字,别虚,点出1234 4.说话量化.具象化:明天下午5.00做完,做不 ...
- 学校acm比赛题
这道题 用位运算必然简单 但是苦逼的是自己不熟练 那就 用本办法 输入一个十进制数 转换成二进制翻转 去掉高位的零 然后再转化为十进制 输出! 1 #include<stdio.h> ...
- 基于ZigBee模块与51单片机之间的简化智能家居项目简介(学生版本)
5月份学校举行比赛,我们团队报名<智能家居>的项目,设计的总体思路用:QT写的上位机与ZigBee无线通信加51作为终端的简易版智能家居 电路连接:PC机->cc2530(协调器)- ...
- 推荐一本写给IT项目经理的好书
原文地址:http://www.cnblogs.com/cbook/archive/2011/01/19/1939060.html (防止原文作者删除.只能拷贝一份了) 推荐一本写给IT项目经理的好书 ...
- C++实现学校运动会管理系统
本文实例为大家分享了C++实现学校运动会管理系统的具体代码,供大家参考,具体内容如下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...
- STL 案例分析
#include <iostream> using namespace std; #include "string" #include <vector> # ...
- 2018年美国大学生数学建模竞赛(MCM/ICM) 比赛心得
话不多说,题目先上: 这是我们这次选择的题目,说说建模的那些事! 美赛的时间和国赛挑战杯时间略有不同,貌似多的一天是为了让我们对文章进行一个翻译吧QAQ 建议参加美赛的同学可以参照此计划进行 Day0 ...
随机推荐
- 枚举Enum转换为List,获取枚举的描述
代码: public class EnumberHelper { public static List<EnumberEntity> EnumToList<T>() { Lis ...
- nignx重启
.进入nginx安装目录sbin下 .输入./nginx -s reload
- Mockplus组件样式库一键解决风格复用
在Mockplus3.3版本中,新增了组件样式库,可以快速复用组件风格,同时可以将组件风格保存到库中. 官网地址:https://www.mockplus.cn 1. 保存样式 选中组件,设置好该组件 ...
- 模板模式c#(非常简单,但又非常简洁好玩)
using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace 模板模式{ ...
- LDA详解
PART 1 这个性质被叫做共轭性.共轭先验使得后验概率分布的函数形式与先验概率相同,因此使得贝叶斯分析得到了极⼤的简化. V:文档集中不重复的词汇的数目 语料库共有m篇文档,: 对于文档,由个词 ...
- mongodb-win32-i386-3.0.6 使用
一.下载地址 https://fastdl.mongodb.org/win32/mongodb-win32-i386-3.0.6.zip 二.安装 1. systeminfo OS 名称: Micro ...
- 与table有关的布局
当IE8发布时,它将支持很多新的CSS display属性值,包括与表格相关的属性值:table.table-row和table-cell,它也是最后一款支持这些属性值的主流浏览器.它标志着复杂CSS ...
- Google Tango service outdated谷歌Tango的服务过时了
If you device showed "tango service outdated." It means that your Tango Core need to be up ...
- [转]How do I run msbuild from the command line using Windows SDK 7.1?
本文转自:http://stackoverflow.com/questions/6319274/how-do-i-run-msbuild-from-the-command-line-using-win ...
- polymer-quick tour of polymer
注册一个元素 <link rel="import" href="bower_components/polymer/polymer.html">//没 ...