L1

您所在的位置:网站首页 考试座位号14是不是考不起了 L1

L1

2024-07-09 12:00| 来源: 网络整理| 查看: 265

作者 CHEN, Yue

单位 浙江大学

每个 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

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

思路:一个学生有学号,试机座位,考试座位,三个变量,学号有16位,考虑用string处理,另外两个用int表示,类型不同,所以用结构体来存储学生的变量

struct student { string xuehao; int seat1; int seat2; };

然后创建n(学生人数)个结构体数组,并且接受输入

cin >> n; //student stu[100]; vector stu(n); for (int i = 0; i < n; i++) { cin >> stu[i].xuehao >> stu[i].seat1 >> stu[i].seat2; }

然后接收m个待查询的试机座位号,并且根据接受的数据,回学生的结构体数组中遍历寻找,找到学生在数组里的下标

int findindex(vector& stu,int x) { for (int i = 0; i < n; i++) { if (stu[i].seat1 == x) { return i; } } }

然后按要求输出

for (int i = 0; i < m; i++) { int temp = findindex(stu,f[i]); cout stu[i].xuehao >> stu[i].seat1 >> stu[i].seat2; } int m; cin >> m; //int f[100] = { 0 }; vector f(m,0); for (int i = 0; i < m; i++) { cin >> f[i]; } for (int i = 0; i < m; i++) { int temp = findindex(stu,f[i]); cout


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3