【算法练习】B1014/A1061.福尔摩斯的约会

输入样例

3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm

输出样例

THU 14:04

代码

#include<bits/stdc++.h>
using namespace std;

char DAY[7][4] = {"MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"};
//int HH[24] = {};
int main()
{
	char str1[70], str2[70], str3[70], str4[70];
	gets(str1);
	gets(str2);
	gets(str3);
	gets(str4);
	int len1 = strlen(str1);
	int len2 = strlen(str2);
	int len3 = strlen(str3);
	int len4 = strlen(str4);
	
	
	int i; // 因为i在后面的循环中还有用,因此不能在for里初始化 
	// 找在str1,str2中第一队 相同位置 的 A~G 的字母
	for(i = 0; i < len1 && i < len2; i++) {
		if(str1[i] == str2[i] && str1[i] >= 'A' && str1[i] <= 'G') {
			printf("%s ", DAY[str1[i] - 'A']);
			break; // 找到 就退出循环 
		}
	} 
	
	// 找在str1,str2中 第二队 相同位置 的 0~9或A~N 的字母
	for(i++ ; i < len1 && i < len2; i++) {
		if(str1[i] == str2[i]) {
			if(str1[i] >= '0' && str2[i] <= '9') {
				printf("%d:", str1[i] - '0'); 
				break;
			} else if(str1[i] >= 'A' && str1[i] <= 'Z') { // 用else if 
				printf("%d:", str1[i] - 'A' + 10);
				break;
			}
		}
	} 
	
	// 找在str3,str4中 第一队 相同位置的 A~Z或a~z 的字母,输出字母所在的位置 
	for(int i = 0; i < len3 && i < len4; i++) {
		if(str3[i] == str4[i]){
			if((str3[i] >= 'A' && str3[i] <= 'Z') || (str3[i] >= 'a' && str3[i] <= 'z')) {
				printf("%02d", i);  // 为了分为个位数时,能输出 例如 01 (%02d:数据宽度不足2时用0填补)
				break;
			}
		}		
	} 
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值