「Mac玩转仓颉内测版14」PTA刷题篇5 - L1-005 考试座位号

ops/2024/11/19 1:18:41/

本篇将继续讲解PTA平台上的题目 L1-005 考试座位号,通过考生准考证号与座位号的对应关系,掌握简单的数据查询与映射操作,进一步提升Cangjie编程语言的实际应用能力。


关键词
  • PTA刷题
  • 数据查询
  • 映射操作
  • 输入输出
  • Cangjie语言

一、L1-005 考试座位号

题目描述:输入若干学生的准考证号与考试座位号,之后再输入若干需要查询的准考证号,输出对应的考试座位号。

  • 输入格式:

    1. 首行给出一个正整数 N,表示考生人数。
    2. 接下来 N 行,每行包含一个准考证号(长度为15的字符串)和一个座位号(1到100之间的整数)。
    3. 最后输入一个正整数 M,表示需要查询的考生数。
    4. 接下来 M 行,每行包含一个准考证号,要求输出对应的座位号。
  • 输出格式:对每个查询的准考证号,输出对应的座位号。


解题思路
  1. 使用字典(映射)存储数据:将准考证号与座位号的对应关系存储在字典(映射)中,方便后续查询。
  2. 输入数据并建立映射:根据考生人数 N,输入准考证号和座位号,建立准考证号到座位号的映射关系。
  3. 查询输出:根据 M 个查询的准考证号,输出相应的座位号。

代码实现
cangjie">package cjcDemoimport std.console.*
import std.convert.*
import std.collection.*class Student {var examId: String          // 准考证号var testSeatId: Int64       // 试机座位号var examSeatId: Int64       // 考试座位号init(examId: String, testSeatId: Int64, examSeatId: Int64) {this.examId = examIdthis.testSeatId = testSeatIdthis.examSeatId = examSeatId}
}// 封装录入学生数据的函数
func inputStudentData(studentCount: Int64): HashMap<Int64, Student> {let studentsMap: HashMap<Int64, Student> = HashMap<Int64, Student>()for (_ in 0..studentCount) {let studentData: Array<String> = Console.stdIn.readln().getOrThrow().split(" ")let parsedTestSeatId = Int64.parse(studentData[1])  // 解析出来的试机座位号let student = Student(studentData[0], parsedTestSeatId, Int64.parse(studentData[2]))  // 学生的准考证号和考试座位号studentsMap.put(parsedTestSeatId, student)}return studentsMap
}// 封装查询学生数据的函数
func queryStudentData(studentsMap: HashMap<Int64, Student>): Unit {let queryIds: Array<String> = Console.stdIn.readln().getOrThrow().split(" ")for (queryId in queryIds) {let parsedQueryId = Int64.parse(queryId)  // 查询的试机座位号let student = studentsMap.get(parsedQueryId).getOrThrow()println("${student.examId} ${student.examSeatId}")}
}// 主函数
main(): Int64 {// 读取学生数量并录入数据let studentCount: Int64 = Int64.parse(Console.stdIn.readln().getOrThrow())let studentsMap = inputStudentData(studentCount)// 读取需要查询的学生数量并进行查询Int64.parse(Console.stdIn.readln().getOrThrow())queryStudentData(studentsMap)return 0
}

代码详解
  1. 映射操作:使用字典(映射)将准考证号与座位号对应起来,方便查询。
  2. 数据输入:根据输入的 N,逐行录入准考证号和座位号,并存储在映射中。
  3. 查询并输出:根据 M 个查询的准考证号,直接从映射中获取并输出对应的座位号。

示例执行

输入:

4
3310120150912233 2 4
3310120150912119 4 1
3310120150912126 1 3
3310120150912002 3 2
2
3 4

输出:

3310120150912002 2
3310120150912119 1

通过这道题目,进一步掌握了映射操作和查询机制,能够高效处理数据并进行输出。


小结

本篇通过实现 L1-005 考试座位号 题目,练习了数据查询与映射操作,能够高效应对类似的映射查询问题,进一步强化了编程实战能力。


下篇预告

下一篇将继续进行PTA刷题,讲解 L1-006 连续因子 的解题思路与实现,敬请期待 「Mac玩转仓颉内测版15」PTA刷题篇6 - L1-006 连续因子


上一篇:「Mac玩转仓颉内测版13」PTA刷题篇4 - L1-004 计算摄氏温度
下一篇:「Mac玩转仓颉内测版15」PTA刷题篇6 - L1-006 连续因子

作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=159
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。



http://www.ppmy.cn/ops/134825.html

相关文章

DAY27|贪心算法Part01|LeetCode:455.分发饼干、376. 摆动序列、53. 最大子序和

贪心算法 贪心的本质是选择每一阶段的局部最优&#xff0c;从而达到全局最优。 贪心算法并没有固定的套路&#xff0c;最难想的就在于如何通过局部最优去推出全局最优。在做一个题目的时候&#xff0c;靠自己手动模拟&#xff0c;如果模拟可行&#xff0c;就可以试一试贪心策略…

源码解析-Spring Eureka(更新ing)

源码解析-Spring Eureka 文章目录 源码解析-Spring Eureka前言一、从Spring.factory和注解开始二、重要的一步EurekaServerInitializerConfiguration三、初始化了什么&#xff1f;自动保护 四, 重新回到EurekaServerAutoConfiguration关于unavailable-replicas 前言 无 一、从…

去地面算法——depth_clustering算法调试(1)

1 源码下载 论文&#xff1a; 《2016-Fast Range Image-Based Segmentation of Sparse 3D Laser Scans for Online Operation》 《2017-Efficient Online Segmentation for Sparse 3D Laser Scans》 代码&#xff1a;git链接 2 问题记录 2.1 无法找到qt问题 问题截图&…

Python 小高考篇(7)常用模板

目录 斐波那契数列常规算法递推法递归法 判断质数常规算法埃氏筛法 最大公因数常规算法辗转相除法 三条边求三角形面积海伦公式 阶乘常规算法递归法 结尾 本文由Jzwalliser原创&#xff0c;发布在CSDN平台上&#xff0c;遵循CC 4.0 BY-SA协议。 因此&#xff0c;若需转载/引用本…

Flutter 新建工程一直等待 解决办法

Flutter报错之Waiting for another flutter command to release the startup lock解决方案 open ~/.bash_profile 此时进入编辑模式&#xff0c;添加如下代理&#xff0c;最后一个是你自己安装的flutter路径 export PUB_HOSTED_URLhttps://pub.flutter-io.cn //国内用户需要…

解析“ChatGPT网络错误”:从网络专线到IP地址的根源与解决方案

在日常使用 ChatGPT 或其他在线服务时&#xff0c;偶尔会遇到“网络错误”的提示&#xff0c;尤其是在请求响应时间较长或出现连接中断的情况下。这种错误常常让用户感到困扰&#xff0c;但实际上&#xff0c;网络错误的发生并不总是因为服务端出现问题&#xff0c;很多时候&am…

【C++ 算法进阶】算法提升十六

目录 背包问题变种 &#xff08;动态规划&#xff09;题目题目分析 连续可组成数字题目题目分析 min-patches题目 最小补丁问题题目分析代码 逆序对个数 &#xff08;归并排序&#xff09;题目题目分析 约瑟夫环问题 &#xff08;公式&#xff09;题目题目分析 背包问题变种 &a…

从浏览器地址栏输入url到显示页面的步骤

1. 输入url&#xff0c;并点击搜索2. 从浏览器获取缓存&#xff08;从浏览器http的header中读取&#xff0c;缓解服务器压力&#xff0c;提高页面加载效率&#xff09; 灰色的200代表是获取的浏览器缓存的数据&#xff0c;黑色的200是后端返回的数据协商缓存&#xff08;优先级…