团体程序设计天梯赛-练习集 L1-005 考试座位号

每个 PAT 考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位。正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座。但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码。

输入格式:
输入第一行给出一个正整数 N(≤1000),随后 N 行,每行给出一个考生的信息:准考证号 试机座位号 考试座位号。其中准考证号由 16 位数字组成,座位从 1 到 N 编号。输入保证每个人的准考证号都不同,并且任何时候都不会把两个人分配到同一个座位上。

考生信息之后,给出一个正整数 M(≤N),随后一行中给出 M 个待查询的试机座位号码,以空格分隔。

输出格式:
对应每个需要查询的试机座位号码,在一行中输出对应考生的准考证号和考试座位号码,中间用 1 个空格分隔。

输入样例:
4
3310120150912233 2 4
3310120150912119 4 1
3310120150912126 1 3
3310120150912002 3 2
2
3 4
输出样例:
3310120150912002 2
3310120150912119 1

# # n=int(input()) #总人数
# # b=[]
# # for i in range(n):
# #     a=list(map(int,input().split()))
# #     b.append(a)  #将b放入列表
# # c=int(input()) #需要查询的人数
# # #found = False  # 添加一个标志位判断是否找到匹配
# # for i in range(c):
# #     d=list(map(int,input().split()))
# # for j in d:
# #     for k in range(n):
# #         if b[k][j] ==j:
# #             print(b[i][0],b[i][1])
# # for j in d:  #比如说为3
# #     for i in range(n):
# #         if b[i][1] == j:
# #             print(b[i][0],b[i][1])
#             #found = True
# ##################
# # N = int(input())   #输入人数
# # a = []
# # b = []
# # c = []
# # for i in range(N):
# #     temp = input().split()
# #     a.append(temp[0])
# #     b.append(int(temp[1]))
# #     c.append(temp[2])
# # M = int(input())  #需要查找人数
# # d = input().split()
# # for i in d:
# #     k = b.index(int(i))
# #     print(a[k], end=' ')
# #     print(c[k])
# ###################
# from collections import deque
# class Student():
#     def __init__(self,num,place1,place2):
#         self.num=num
#         self.place1=place1
#         self.place2=place2
# n=int(input())
# deque1=deque()
# for i in range(n):
#     try:
#         w=list(map(eval,input().split(" ")))
#         deque1.append(Student(w[0],w[1],w[2]))
#     except:
#         print("cowu")
# m=int(input())
# list1=list(map(eval,input().split(" ")))
# for i in list1:
#     for student in deque1:
#         if student.place1==i:
#             print("{} {}".format(student.num,student.place2))
 
N = int(input())    #输入得到正整数N
student = []        #建立一个考生信息列表
for i in range(N) : #循环考生个数
    student.append(list(input().split(' ')))    #以空格分隔,得到考生的“准考证号 试机座位号 考试座位号”,并将每个考生的信息形成一个单独的列表,添加到student列表中
M = int(input())    #输入得到正整数M
testSeatNumber = []
testSeatNumber.extend(list(input().split(' '))) #随后一行中给出 M 个待查询的试机座位号码,以空格分隔
for j in testSeatNumber :   #j依次取需要查询的试机号码
    for i in student :      #i依次取每个学生的信息
        if j == i[1] :      #将需要查询的试机号码与每个学生的信息中的试机号码对比,若一样输出结果
            print("{} {}".format(i[0], i[2]))   #输出对应考生的准考证号i[0]和考试座位号码i[2]
            student.remove(i)   #移除已经查询的考生信息,…这个操作本来是没有的,后来发现,很容易超时,所以加的。但是,我发现耗时还是有点长…,160ms,我也不知道怎么改了…,欢迎大佬批评指正。
 

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值