1029 旧键盘 (20 分)

本文介绍了一种使用C++实现的简单字符串处理方法,通过对比两个字符串并利用Hash记录已出现过的字符,来判断键盘上哪些字母键可能已经损坏。这种方法可以有效地避免重复输出相同字母,并且能够正确处理大小写字母。

解题思路:本题还是比较简单的,主要是对字符串的处理,利用hash识别是否输出过,对于大小写字母任意一个出现,就代表该键已坏,所以后续该键不必输出。

#include<cstdio>
#include<cstring>
int main(){
	char in[100],out[100];
	scanf("%s%s",in,out);
	int len1=strlen(in);
	int len2=strlen(out);
	int Hash[200]={0};
	int j=0;
	for(int i=0;i<len1;i++){
		if(in[i]!=out[j]){
			if(Hash[in[i]-0]==0) { //如果说是第一次出现 
			if(in[i]>='a'&&in[i]<='z'){ //小写字母 
				printf("%c",in[i]-32);
				Hash[in[i]-0]=1;
				Hash[in[i]-32]=1;
			}else if(in[i]>='A'&&in[i]<='Z'){ //大写字母 
				printf("%c",in[i]);
				Hash[in[i]-0]=1;
				Hash[in[i]+32]=1;
			}else{    //数字 
				 printf("%c",in[i]);
				 Hash[in[i]-0]=1;
			     } 
			}
			
		}else j++;
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值