某市举行一场演讲比赛,共有24个人参加,按参加顺序设置参赛号。比赛共三轮,前两轮为淘汰赛,第三轮为决赛。
比赛方式:分组比赛
第一轮分为4个小组,根据参赛号顺序依次划分,比如100-105为一组,106-111为第二组,依次类推,每组6个人,每人分别按参赛号顺序演讲。
当小组演讲完后,淘汰组内排名最后的三个选手,然后继续下一个小组的比赛。
第二轮分为2个小组,每组6人,每个人分别按参赛号顺序演讲。当小组完后,淘汰组内排名最后的三个选手,然后继续下一个小组的比赛。
第三轮只剩下6个人,本轮为赛决,选出前三名。
选手每次要随机分组,进行比赛。
比赛评分:10个评委打分,去除最低、最高分,求平均分
每个选手演讲完由10个评委分别打分。该选手的最终得分是去掉一个最高分和一个最低分,求得剩下的8个成绩的平均分。选手的名次按得分降序排列,
若得分一样,按参赛号升序排名。
用STL编程,求解一下问题
1.请打印出所有选手的名字与参赛号,并以参赛号的升序排列。
2.打印每一轮比赛前,分组情况
3.打印每一轮比赛后,小组晋级名单
4.打印决赛前三名,选手名称、成绩。
main.cpp文件
#include "manager.h"
using namespace std;
int main(void)
{
Manager m;
m.show();
return 0;
}
Speaker.h文件
#pragma once
#include <string>
#include <vector>
#include <iostream>
using namespace std;
class Speaker
{
public:
void setName(string s);
string getName();
void setScore(int n);
int getScore(int n);
void setNumber(int n);
int getNumber();
private:
string name;
int number;
vector<int>scores;
};
Speaker.cpp文件
#include "Speaker.h"
void Speaker::setName(string s) {
this->name = s;
}
string Speaker::getName() {
return this->name;
}
void Speaker::setScore(int n) {
//n是第n+1次成绩
this->scores.push_back(n);
}
int Speaker::getScore(int n) {
if (n < 0 || n>2)
cout << "error";
return this->scores[n];
}
void Speaker::setNumber(int n) {
this->number = n;
}
int Speaker::getNumber() {
return this->number;
}
Manager.h文件
#pragma once
#define SPEAKER_NUMBER 24
#include <string>
#include <vector>
#include <map>
#include <iostream>
#include <algorithm>
#include <time.h>
#include <deque>
#include <functional>
#include "Speaker.h"
using namespace std;
class Manager
{
public:
void create_speaker();
void divid_speaker();
void first_game();
void second_game();
void final_game();
void show();
private:
vector<Speaker> first_vector;
vector<Speaker>