《PTA——拼题A》之第1014题

福尔摩斯收到一张包含乱码的字条,通过解析特定的字符串对,揭示了隐藏的约会时间和日期。输入四行字符串,输出解码后的日期和时间。

题目介绍

大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间星期四 14:04,因为前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母 D,代表星期四;第 2 对相同的字符是 E,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母 A 到 N 表示);后面两字符串第 1 对相同的英文字母 s 出现在第 4 个位置(从 0 开始计数)上,代表第 4 分钟。现给定两对字符串,请帮助福尔摩斯解码得到约会的时间。

输入格式:
输入在 4 行中分别给出 4 个非空、不包含空格、且长度不超过 60 的字符串。

输出格式:
在一行中输出约会的时间,格式为 DAY HH:MM,其中 DAY 是某星期的 3 字符缩写,即 MON 表示星期一,TUE 表示星期二,WED 表示星期三,THU 表示星期四,FRI 表示星期五,SAT 表示星期六,SUN 表示星期日。题目输入保证每个测试存在唯一解。

输入样例 :

3485djDkxh4hhGE 
2984akDfkkkkggEdsb 
s&hgsfdk 
d&Hyscvnm

输出样例 :

THU 14:04

源代码

#include<cstdio>
#include<cstring>
const int MAX_N = 62;

int main(){
  char DAY[7][4] = {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
  char str1[MAX_N], str2[MAX_N], str3[MAX_N], str4[MAX_N];
  int i = 0;
  bool flag = false;
  scanf("%s", str1);
  scanf("%s", str2);
  scanf("%s", str3);
  scanf("%s", str4);
  for(; str1[i] != '\0' && str2[i] != '\0'; ++i){
    if(str1[i] == str2[i]){
      if(str1[i] >= 'A' && str1[i] <= 'G' && !flag){
          flag = true;
          printf("%s ", DAY[str1[i] - 'A']);
          continue;	//	周一到周日
      }else if(str1[i] >= 'A' && str1[i] <= 'N' && flag){
          printf("%02d:", str1[i] - 'A' + 10);
          break;	//	10~23点
      }else if(str1[i] >= '0' && str1[i] <= '9' && flag){
          printf("%02d:", str1[i] - '0');
          break;	//	0~9点
      }
    }
  }
  for(i = 0; str3[i] != '\0' && str4[i] != '\0'; ++i){
    if(str3[i] >= 'A' && str3[i] <= 'z' && str3[i] == str4[i]){
      printf("%02d", i);	//	分钟
      break;
    }
  }
  return 0;
}
### PTA C语言编程练习与解决方案 PTA程序设计类实验辅助教学平台是一个在线编程平台,旨在为学生提供良好的编程实践环境,帮助他们掌握编程语言和编程思想,从而提升程序设计能力[^1]。该平台上提供了大量的编程练习目和实验目,涵盖了C语言的基础语法、数据结构以及算法等内容。 以下是几个常见的PTA C语言编程问及其解决方案: #### 1. 输出格式严格要求 在某些情况下,PTA会对输出格式有严格的限制。例如,在处理数组输出时,可能会遇到如下情况:当使用`printf("%d ", A[n])`输出最后一个数后带有多余的空格,这可能导致测试用例无法通过。此时可以通过单独处理最后一项来避免多余空格的发生[^4]。 ```c for (int i = 0; i < n - 1; i++) { printf("%d ", A[i]); } if (n > 0) { // 防止输入为空的情况 printf("%d", A[n - 1]); // 单独打印最后一项 } ``` #### 2. 素数判定问 素数是指除了1和它本身以外不再能被其他自然数整除的大于1的自然数。在PTA上的素数相关目通常会涉及如何高效地判断一个数是否为素数,并且需要注意输出格式的要求,比如数字间需留有间隔而行末不得多出空格[^5]。 一种简单的实现方法如下所示: ```c #include <stdio.h> #include <math.h> // 判断是否为素数函数 int isPrime(int num) { if (num <= 1) return 0; int sqrtNum = sqrt(num); for (int i = 2; i <= sqrtNum; i++) { if (num % i == 0) return 0; } return 1; } void printPrimes(int start, int end) { int firstFlag = 1; // 控制首项标志位 for (int i = start; i <= end; i++) { if (isPrime(i)) { if (!firstFlag) printf(" "); // 如果不是首个元素则先加空格 printf("%d", i); // 打印当前素数值 firstFlag = 0; // 设置后续非首次标记 } } putchar('\n'); // 行结束符 } int main() { int a, b; scanf("%d%d", &a, &b); printPrimes(a, b); return 0; } ``` 此代码片段定义了一个用于检测给定范围内所有素数的功能模块,并妥善解决了连续输出间的分隔及结尾无冗余字符的问。 #### 3. 学生管理系统初步构建 为了验证学习者对C语言的理解程度,许多课程都会布置开发简易的学生管理系统的作业作为综合考核项目之一。这类系统一般包括但不限于以下几个功能点:录入学员基本信息、查询特定条件下的记录列表、修改已有条目属性值以及删除指定对象等功能操作[^3]。 下面展示的是一个非常基础版本框架示意: ```c typedef struct Student { char name[20]; int id; }Student; #define MAX_STUDENTS 100 Student students[MAX_STUDENTS]; // 定义存储空间大小 int studentCount = 0; // 当前已存入数量计数器变量声明初始化为零 void addStudent(Student s){ if(studentCount >=MAX_STUDENTS ){ puts("No more space!"); return ; } students[studentCount++]=s; } void displayAll(){ for(int i=0;i<studentCount;i++){ printf("ID:%d Name:%s\n",students[i].id,students[i].name); } } int main(){ Student temp={}; while(1){ printf("\nEnter command(add/display/exit):"); char cmd[10]; scanf("%s",cmd); if(strcmp(cmd,"add")==0){ printf("Enter ID and NAME:"); scanf("%d%s",&temp.id,temp.name); addStudent(temp); }else if(strcmp(cmd,"display")==0){ displayAll(); }else if(strcmp(cmd,"exit")==0){ break; } } return 0; } ``` 上述例子仅展示了最简单的核心逻辑架构,实际应用中还需要考虑更多边界状况处理机制等问。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值