浏览 1835 次
锁定老帖子 主题:003排名
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (7)
|
|
---|---|
作者 | 正文 |
发表时间:2009-04-13
最后修改:2009-04-13
对每组数据,首先输入一个n(1<=n<=10000),表示参赛队伍的数量。然后有n行,每行为: Team-name Problems Penalty Info 其中Team-name表示队名(长度不超过20),Problems表示解题数量(32位有符号整数可以表示),Penalty表示罚时(32位有符号整数可以表示),Info为M表示女队,N表示正常队伍。 排序后的结果,格式与输入相同。 首先根据题目数量由多至少,同等题目情况下女队优先,然后罚时少者优先,最后按队名字典序。 每组样例后输出一个空行。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-04-15
简单的赛程排名:
#include <iostream> using namespace std; #define ARRAYLENGTH 9 #define GROUPLENGTH 10000 #include <math.h> #include <ctype.h> #include <vector> #include <algorithm> char* splitDigit(string digitStr); //char* splitInt(int a); bool isDigit(string testCaseCout); int get_Int(char c); int stringToInt(string teamName); bool isLetter(string str); //int calculate(int number); char get_Char(int c); bool checkDigit(char c); bool checkNORM(char c); bool compareString(string str1,string str2); /* 数据的复杂度,此程序目前测试用例为1个 首先根据题目数量由多至少,同等题目情况下女队优先,然后罚时少者优先,最后按队名字典序。 */ /* 字典排序 */ char *c = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; char number[ARRAYLENGTH] = {'1','2','3','4','5','6','7','8','9'}; struct paiming { string teamName; int problems; int penalty; char info; }; bool comparator(struct paiming p1,struct paiming p2); void byLetter(vector<struct paiming> v); /*按解题数排序*/ bool proSort(struct paiming p1,struct paiming p2) { int t1 = p1.problems; int t2 = p2.problems; if(t1 != t2) { return t1 > t2; } return true; } /*按N/M排序*/ bool infoSort(struct paiming p1,struct paiming p2) { int t1 = p1.problems; int t2 = p2.problems; if(t1 == t2) { char i1 = p1.info; char i2 = p2.info; if(i1 != i2) { if(i1 == 'M') { return true; }else { return false; } } }else { return proSort(p1,p2); } return true; } /*按罚时排序*/ bool paSort(struct paiming p1,struct paiming p2) { int t1 = p1.problems; int t2 = p2.problems; char c1 = p1.info; char c2 = p2.info; if(t1 == t2 && c1 == c2) { int i1 = p1.penalty; int i2 = p2.penalty; if(i1 != i2) { return i1 < i2; } }else { if(t1 == t2) { if(c1 == 'M') { return true; }else { return false; } }else { return proSort(p1,p2); } } return true; } /*字典排序*/ bool compareString(string str1,string str2) { char c1,c2; string ts; if(str1.length() >= str2.length()) { ts = str2; } else { ts = str1; } for(int i = 0;i < ts.length();i++) { if((c1 = str1[i]) != (c2 = str2[i])) { return c1 < c2; } } return true; } bool comparator_letter(struct paiming p1,struct paiming p2) { int t1 = p1.problems; int t2 = p2.problems; char c1 = p1.info; char c2 = p2.info; int i1 = p1.penalty; int i2 = p2.penalty; if(t1 == t2 && c1 == c2 && i1 == i2) { string t1 = p1.teamName; string t2 = p2.teamName; return compareString(t1,t2); }else { if(t1 == t2) { if(c1 == c2) { return i1 < i2; }else { if(c1 == 'M') { return true; }else { return false; } } }else { return proSort(p1,p2); } } return true; } /*------------------以上为排序------------------------------*/ /*检验是否是N或者M*/ bool checkNORM(char c) { if(c == 'M' || c == 'N') { return true; } return false; } /*检验是否为数字*/ bool checkDigit(string a) { bool flag = true; char *p= splitDigit(a); while(*p != '\0') { char pp = *p++; if(pp < '0' || pp > '9') { flag = false; break; } } return flag; } /*检验是否为字母*/ bool isLetter(string str) { for(int i = 0;i < str.length();i++) { char c = str[i]; char up_c = toupper(c); if(up_c < 'A' || up_c > 'Z') { return false; }else { continue; } } return true; } /*判断数字*/ bool isDigit(string testCaseCout) { bool flag = true; char *p = splitDigit(testCaseCout); while(*p != '\0') { int i = 0; char pp = *p++; while(i < ARRAYLENGTH) { if(pp == number[i]) { break; } else { if(i == ARRAYLENGTH - 1) { flag = false; break; } i++; continue; } } if(!flag) break; } return flag; } /*将string化为int型*/ int stringToInt(string teamName) { int sum = 0; char str[10000] = {'\0'}; for(int i = 0;i < teamName.length();i++) { str[i] = teamName[i]; int ii = get_Int(str[i]); double d = pow(10,teamName.length()-i-1); sum += (int)(ii * d); } return sum; } /*拆分字符串*/ char* splitDigit(string digitStr) { int _len = digitStr.length(); static char str[100] = {'\0'}; for(int i = 0;i < _len;i++) { str[i] = digitStr[i]; } return str;//不能返回栈空间即将释放的内存空间 } /*原先字符当作数字*/ int get_Int(char c) { static int cc = 0; switch (c) { case '1': cc = 1; break; case '2': cc = 2; break; case '3': cc = 3; break; case '4': cc = 4; break; case '5': cc = 5; break; case '6': cc = 6; break; case '7': cc = 7; break; case '8': cc = 8; break; case '9': cc = 9; break; default: cc = 0; break; } return cc; } void t() { string testCaseCout; cout<<"输入测试用例数量:"<<endl;// cin>>testCaseCout; while(!isDigit(testCaseCout)) { cout<<"测试用例数量不是数字,请重新输入:"<<endl; cin>>testCaseCout; } int testCaseNumber = stringToInt(testCaseCout); string groupCount; cout<<"输入参赛队伍数量:"<<endl; cin>>groupCount; while(!isDigit(testCaseCout)) { cout<<"参赛队伍数量不是数字,请重新输入:"<<endl; cin>>groupCount; } int _groupCount = stringToInt(groupCount); while(_groupCount< 0 || _groupCount > GROUPLENGTH) { cout<<"参赛队伍数量在1~10000,请重新输入:"<<endl; cin>>groupCount; } _groupCount = stringToInt(groupCount); struct paiming pa; vector<struct paiming> v; cout<<"请分别输入队名,解题数量,罚时,Info:"<<endl; string prob,penal; for(int i = 0;i < _groupCount;i++) { cin>>pa.teamName>>prob>>penal>>pa.info; while(!isLetter(pa.teamName) || !checkNORM(pa.info)) { cout<<"请输入对应的类型数据:"<<endl; cin>>pa.teamName>>prob>>penal>>pa.info; } pa.problems = stringToInt(prob); pa.penalty = stringToInt(penal); v.push_back(pa); } sort(v.begin(),v.end(),comparator_letter); for(vector<struct paiming>::const_iterator iter = v.begin() ; iter < v.end() ; ++iter) { cout<<iter->teamName<<" "<<iter->problems<<" "<<iter->penalty<<" "<<iter->info<<endl; } } int main() { t(); system("PAUSE"); } |
|
返回顶楼 | |