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 ...
随机推荐
- ASP.NET文件上传大小限制
上传限制 我们以为的文件大小限制 我们大家都知道ASP.NET为我们提供了文件上传服务器控件FileUpload,默认情况下可上传的最大文件为4M,如果要改变可上传文件大小限制,那么我们可以在web. ...
- Entity Framework 6.0 对枚举的支持/实体添加后会有主键反回
实验 直接上代码,看结果 实体类 [Flags] public enum FlagsEnum { Day = , Night = } public class EntityWithEnum { pub ...
- background image
http://www.ajaxblender.com/bgstretcher-2-jquery-stretch-background-plugin-updated.html http://blog.d ...
- 服务器上创建git仓库
1. 在服务器上 su - git ,切换用户 2. 创建一个目录 mkdir test.git ,请注意带上 .git 扩展 3. 切换进入此目录,git init --bare ,初始化裸 ...
- linux 查找php.ini在那个文件夹
第一种方法:通过phpinfo查看 第二种方法: 执行 php -i | grep php.ini 结果如下:
- thinkphp 调用wsdl接口实例化SoapClient抛出异常
异常:Message:SOAP-ERROR: Parsing WSDL: Couldn't load from 'http://*****?wsdl' : failed to load externa ...
- SpringMVC源码解析 - HandlerAdapter - HandlerMethodArgumentResolver
HandlerMethodArgumentResolver主要负责执行handler前参数准备工作. 看个例子,红色部分的id初始化,填充值就是它干的活: @RequestMapping(value ...
- 基于jCOM搭建Java-微软信息桥梁(下)
第一部分析了BEA提供的Java/COM互操作解决方案—jCOM的实现原理:本文是第二部分,比较全面地分析了Weblogic Server的jCOM实现技术之后,通过一个具体实例来说明了jCOM的具体 ...
- 封装MongoDB的 asp.net 链接类
using System;using System.Collections.Generic;using System.Linq;using MongoDB; /// <summary>// ...
- Sql Server中使用存储过程来实现一些时间差的改变
Sql Server中的时间差是使用DATEDIFF来是现的 语法如下:DATEDIFF(要显示时间格式,开始时间,结束时间) 比如:DATEDIFF(minute,'2019-2-28 8:30', ...