1029 旧键盘(toupper())

本文介绍了一道关于找出损坏键盘上坏掉按键的编程题。通过对比输入和输出字符串来确定哪些键无法正常工作,并提供了解决方案的两种不同实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。

输入格式:

输入在 2 行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过 80 个字符的串,由字母 A-Z(包括大、小写)、数字 0-9、以及下划线 _(代表空格)组成。题目保证 2 个字符串均非空。

输出格式:

按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有 1 个坏键。

输入样例:

7_This_is_a_test
_hs_s_a_es

输出样例:

7TI

分析:

       这道题不难,但是害苦了我。首先我又犯了以往的错误,把题想复杂了,一开始我考虑如果一个键有时输出有时不输出算不算坏键。后来发现这压根儿就不在题目范围内好吧!如果一个键是坏的,那么它根本就不会输出!总的来说整体思路很简单,对每一个s1的字符检索它是否在s2中,检查完后输出,注意大小写的问题。但我的代码写的特别复杂,如下:

#include<iostream>
#include<string.h>

using namespace std;

int main(){
	char s1[100], s2[100];
	int ptr1 = 0;
	int disabled[100], cnt = 0, characters[26], nums[11];
	memset(characters, 0, sizeof(characters));
	memset(nums, 0, sizeof(nums));
	cin >> s1 >> s2;
	while(s1[ptr1] != '\0'){
		//在s2中寻找对应字符
		int i = 0;
		while(s2[i] != '\0'){
			if(s2[i] == s1[ptr1]) break;
			else i++;
		}
		//没找到
		if(s2[i] == '\0') disabled[cnt++] = ptr1;
		ptr1++;
	}
	//输出
	for(int i = 0; i < cnt; i++){
		if(s1[disabled[i]] >= 'a' && s1[disabled[i]] <= 'z'){
			if(characters[s1[disabled[i]] - 'a'] == 0){
				char temp = s1[disabled[i]] - 32;
				cout << temp;
				characters[s1[disabled[i]] - 'a'] = 1;
			}
		}else if(s1[disabled[i]] >= 'A'&& s1[disabled[i]] <= 'Z'){
			if(characters[s1[disabled[i]] - 'A'] == 0){
				cout << s1[disabled[i]];
				characters[s1[disabled[i]] - 'A'] = 1;
			}
		}else if(s1[disabled[i]] >= '0' && s1[disabled[i]] <= '9'){
			if(nums[s1[disabled[i]] - '0'] == 0){
				cout << s1[disabled[i]];
				nums[s1[disabled[i]] - '0'] = 1;
			}
		}else if(s1[disabled[i]] == '_'){
			if(nums[10] == 0){
				cout << '_';
				nums[10] = 1;
			}
		}
	}
}

       其中因为一个方括号的问题,卡了我很久很久!横竖不知道哪里错了,还不知道样例是什么,真让人捉急!后来在一个网站终于找到了样例,才发现程序的问题,竟然是少了一个方括号!我还纳闷这样其他的测试点竟然都能过!果然程序写复杂了真的不容易找其中的错误,看其他博客有十分简洁的代码:

#include<cstdio>
#include<cstring>
#include<cctype>

using namespace std;

int a[200] = {0};

int main(){
	char str1[100], str2[100];
	scanf("%s %s", str1, str2);
	int len1 = strlen(str1), len2 = strlen(str2);
	for(int i = 0; i < len2; i++)
		a[toupper(str2[i])]++;
	for(int i = 0; i < len1; i++){
		a[toupper(str1[i])]--;
		if(a[toupper(str1[i])] == -1) printf("%c", toupper(str1[i]));
	}
}

       其中toupper包含在<cctype>头文件中。

03-11
<think>好的,用户想了解C++中的toupper函数的用法以及如何在字符串中使用它。首先,我需要回忆toupper函数的基本功能,它用于将字符转换为大写。根据引用[1],toupper和tolower确实在<cctype>头文件中定义,处理单个字符。 用户提到的是C++中的string类,可能需要将整个字符串转换为大写。这时候,常见的方法是遍历字符串的每个字符,并逐个应用toupper。例如引用[2]中的代码示例,使用循环来处理每个字符。不过,这样做可能效率不高,但足够简单。 另外,引用[2]还提到了transform算法,结合begin和end迭代器,以及::toupper函数,可以更简洁地转换整个字符串。这种方法更符合C++标准库的风格,应该推荐给用户。 需要注意的是,toupper的参数是int类型,返回也是int,所以需要强制转换回char。这在处理string的字符时很重要,否则可能会有类型不匹配的警告或错误。 用户可能还关心跨语言的情况,比如JavaScript中的实现,如引用[3]所述,但用户主要问的是C++,所以这部分可能作为相关问题提及,但不需要在回答中展开。 总结回答结构:先介绍toupper的基本用法,给出单个字符的例子,然后展示如何应用到整个字符串,包括循环和transform两种方法。最后附上相关问题,覆盖其他语言或其他函数,如tolower,以及错误处理。</think>### C++中`toupper`函数用法详解 `toupper`是C++标准库中用于将字符转换为大写的函数,定义在`<cctype>`头文件中。以下是其具体用法和示例: #### 1. 单个字符转换 `toupper`接受一个字符(类型为`int`或`char`),返回其大写形式。若字符不是小写字母,则返回原值。 ```cpp #include <cctype> #include <iostream> using namespace std; int main() { char c = 'a'; cout << toupper(c); // 输出:65(ASCII值) cout << (char)toupper(c); // 输出:'A' return 0; } ``` #### 2. 字符串转换 若需将整个`string`转换为大写,可以通过遍历或使用`transform`算法实现: - **方法1:循环遍历** ```cpp #include <string> #include <cctype> string s = "Hello"; for (int i = 0; i < s.size(); i++) { s[i] = toupper(s[i]); // 逐个字符转换 } cout << s; // 输出:"HELLO" ``` - **方法2:使用`transform`算法** ```cpp #include <algorithm> #include <cctype> string s = "World"; transform(s.begin(), s.end(), s.begin(), ::toupper); // 转换整个字符串 cout << s; // 输出:"WORLD" ``` #### 3. 注意事项 - 需包含头文件`<cctype>`和`<algorithm>`(使用`transform`时)。 - `toupper`返回的是`int`类型,赋值给`char`时建议显式转换。 - 非字母字符(如数字或符号)会被直接返回,不会修改[^1][^2]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值