PAT Basic Level 1059 C语言竞赛 解题思路及AC代码

2024-03-29 14:18

本文主要是介绍PAT Basic Level 1059 C语言竞赛 解题思路及AC代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PAT 乙级 1059 C语言竞赛 v1.0

    • 1. 题目简述及在线测试位置
    • 2. 基本思路
    • 3. 完整AC代码

1. 题目简述及在线测试位置

1.1 给定学生考号和名次信息,按要求输出获得的奖品
1.2 在线测试位置: 1059 C语言竞赛

2. 基本思路

2.1 本题考查了数据结构的概念:数据在计算机中如何存储?良好的存储方式 决定了 良好的数据处理效率。本文使用了结构体数组:数组下标代表学生ID、结构体中index字段代表名次、结构体中Received字段代表是否可以获得奖品

struct Info
{int index=0; //名次,默认0表示无效bool Received=true; //是否有资格获得奖品,默认为是
}a[MAX]; //数组a的下标代表学生ID

2.2 据此存储数据,然后按输入条件进行判定即可

3. 完整AC代码

#include <string> //stoi()
#include <iostream>
using namespace std;#define MAX 10001struct Info
{int index=0; //名次,默认0表示无效bool Received=true; //是否有资格获得奖品,默认为是
};bool isPrime(int Number);int main()
{struct Info a[MAX]; //数组a的下标代表学生IDint N, ID; cin >> N;for (int i = 1; i <= N; i++){cin >> ID;a[ID].index = i;}int Query; //查询次数string Identi; //查询IDcin >> Query;while (Query--){cin >> Identi;if (!a[stoi(Identi)].index) //无效名次cout << Identi << ": Are you kidding?" << endl;else if (!a[stoi(Identi)].Received) //已收到礼物cout << Identi << ": Checked" << endl;else if (a[stoi(Identi)].index == 1 ){cout << Identi << ": Mystery Award" << endl;a[stoi(Identi)].Received = false;}		else if ( isPrime(a[stoi(Identi)].index) ){cout << Identi << ": Minion" << endl;a[stoi(Identi)].Received = false;}else if ( !isPrime(a[stoi(Identi)].index) ){cout << Identi << ": Chocolate" << endl;a[stoi(Identi)].Received = false;}}return 0;
}bool isPrime(int Number)
{int N = Number;if (N > 1){for (int i = 2; i * i <= N; i++)if (N % i==0)return false;}else if(N == 1)return false;return true;
}

这篇关于PAT Basic Level 1059 C语言竞赛 解题思路及AC代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/858815

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

vscode保存代码时自动eslint格式化图文教程

《vscode保存代码时自动eslint格式化图文教程》:本文主要介绍vscode保存代码时自动eslint格式化的相关资料,包括打开设置文件并复制特定内容,文中通过代码介绍的非常详细,需要的朋友... 目录1、点击设置2、选择远程--->点击右上角打开设置3、会弹出settings.json文件,将以下内

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ