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 ...
随机推荐
- Java 设计模式系列(八)装饰者模式
Java 设计模式系列(八)装饰者模式 装饰模式又名包装(Wrapper)模式.装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案.Decorator 或 Wrapper 一.装饰模 ...
- 图灵社区 书单推荐:成为Java顶尖程序员 ,看这11本书就够了
java书单推荐 转自 http://www.ituring.com.cn/article/211418 “学习的最好途径就是看书“,这是我自己学习并且小有了一定的积累之后的第一体会.个人认为看书有两 ...
- Redis安装部署、Jedis的使用
一.NoSQL概述 为什么需要NoSQL High performance -高并发读写 Huge Storage - 海量数据的高效率存储和访问 High Scalability && ...
- cucumber安装步骤
#Start Guide##Environment###1. Install Ruby Verify your installation by running ruby -v in a termina ...
- 整理悬浮在列表中a元素时改变a元素上下边框颜色的问题。
整理一下当悬浮在a元素上时a的上下边颜色改变,并且里面的内容不会移动,下面是PSD图效果区域: 刚开始我先给A元素加了上下边框和颜色,利用a:hover改变a元素上下的边框颜色,但是第一个a元素的下边 ...
- ORA-00054、ORA-08002
https://docs.oracle.com/cd/B10501_01/server.920/a96525/e7500.htm ORA-00054 resource busy and acquire ...
- Shell编程-02-Shell变量
目录 什么是Shell变量 变量类型 环境变量初始化及其对应文件的生效顺序 什么是Shell变量 在初等数学数学方程式中,我们会经常碰到类似于这样的方程式:y=x+1 ,等号左右两边的x和y称 ...
- (连通图 缩点 强联通分支)Popular Cows -- poj --2186
http://poj.org/problem?id=2186 Description Every cow's dream is to become the most popular cow in th ...
- POJ3281 Dining 2017-02-11 23:02 44人阅读 评论(0) 收藏
Dining Description Cows are such finicky eaters. Each cow has a preference for certain foods and dri ...
- handsontable-developer guide-cell type
单元格类型:这里有很多没见过的用法,得好好总结一下 //预定义的类型Text Numeric Checkbox Date Select Dropdown Autocomplete Password H ...