南邮 OJ 2040 比赛成绩查询问题II

比赛成绩查询问题II

时间限制(普通/Java) :  1000 MS/ 3000 MS          运行内存限制 : 81920 KByte
总提交 : 403            测试通过 : 53 

比赛描述

2014“华为杯南京邮电大学大学生团体歌唱大赛参赛团队的队名由“2014nupthw”和顺序号组合而成,例如2014nupthw0012014nupthw0022014nupthw0282014nupthw089等。大赛结束后,任何人都可以通过队名查询任何一支队伍的排名,同时也可以通过排名查询队名,这里队伍排名从1开始且无并列情况。主办方提供所有参赛团队队名和排名的对应列表以及需要咨询的参赛团队队名或排名,请你完成此次大赛的成绩查询工作。



输入

输入包括多个行:第1行给出参赛团体总数N、需要查询成绩的参赛团队数;接下来有N行,每一行先后给出参赛团体的队名和最终排名;接下来有M行,每一行给出需要查询排名的参赛团队的队名或者需要查询参赛团体队名的排名。这里1≤N<100001≤M≤1000000


输出

对应输入中最后M行要查询排名的参赛团队的队名或者需要查询参赛团体队名的排名,输出M行,每一行给出要查询的相应参赛团队队名、排名,以一个空格分隔上述两项内容。


样例输入

4 3
2014nupthw089 2
2014nupthw028 1
2014nupthw001 4
2014nupthw002 3
2014nupthw002
2
2014nupthw028

样例输出

2014nupthw002 3
2014nupthw089 2
2014nupthw028 1

题目来源

SED






#include<iostream>
int nameToNo[1000];
int NoToName[10001];

int main(){
//	freopen("test.txt","r",stdin);
	int n,m,name,No;
	char c[14],*p;
	scanf("%d%d",&n,&m);
	while(n--){
		scanf("%s%d",c,&No);
		name = (c[10]-'0')*100 + (c[11]-'0')*10 + (c[12]-'0');
		nameToNo[name] = No;
		NoToName[No] = name;
	}
	while(m--){
		c[1]=c[2]=c[3]=c[4]=c[5]=0;			//这一优化时间没变
		scanf("%s",c);
		if(c[5]){
			name = (c[10]-'0')*100 + (c[11]-'0')*10 + (c[12]-'0');
			printf("%s %d\n",c,nameToNo[name]);
		}else{
			p = c;
			No = 0;
			while(*p){
				No = No*10 + *p-'0';
				p++;
			}
			printf("2014nupthw%03d %d\n",NoToName[No],No);
		}
	}
}


你可能感兴趣的:(ACM,南邮OJ,比赛成绩查询问题II)