#PAT1014练习完美通关c语言详解
##题解
###题目分析
本题主要考察对ASCLL码的应用以及字符串的相关知识。由题目来看,应该分为三个输出
1.星期几,首先对前两个字符串进行一一的字符检测,这次是仅限大写英文字母,对应A-G,可以做一个有关星期的字符的二维数组方便输出。
2.时辰,分为0-9,10-24两个区间,在第一个星期输出完后继续在后面检测数字或大写英文字母,再输出相应的时辰即可。
3.分钟,仅限查找英文字母,通过在第n个字母相同即输出n为答案。
###难点
1.对ASCLL码对应的字符需要一定的了解及相关操作。
2.学到了个小技巧,%02d中2是指宽度,若没有两位则自动补零,这能很好的简化代码。
##代码
#include <stdio.h>
#include <string.h>
#define Max 100
int main()
{
char day[7][4]={"MON","TUE","WED","THU","FRI","SAT","SUN"};
char a[100],b[100],c[100],d[100];
gets(a);gets(b);gets(c);gets(d);
int i,flag=0;
for(i=0;i<strlen(a)&&strlen(b); i++)
{
if(flag==0){
if(a[i]==b[i]&&a[i]>='A'&&a[i]<='G')
{
printf("%s ",day[a[i]-'A']);
flag+=1;
}
}
else{
if(a[i]==b[i]&&a[i]>='A'&&a[i]<='N')
{
printf("%2d:",a[i]-'A'+10);
break;
}
else if(a[i]==b[i]&&a[i]>='0'&&a[i]<='9')
{
printf("%02d:",a[i]-'0');
break;
}
}
}
for(i=0;i<strlen(c)&&strlen(d);i++)
{
if(c[i]==d[i]&&(c[i]>='A'&&c[i]<='Z'||c[i]>='a'&&c[i]<='z'))
{
printf("%02d",i);
break;
}
}
return 0;
}