给大家分享一句我很喜欢我话: 知不足而奋进,望远山而前行!!! 铁铁们,成功的路上必然是孤独且艰难的,但是我们不可以放弃,远山就在前方,但我们能力仍然不足,所有我们更要奋进前行!!! 今天我们更新了x字母大小写转换x内容,
#include<stdio.h>
int main()
{
char ch;
printf("请输入一个字符:\n");
scanf("%c", &ch);
if (ch >= 'a' && ch <= 'z')
{
ch -= 32;
printf("%c\n", ch);
}
else if (ch >= 'A' && ch <= 'Z')
{
ch += 32;
printf("%c\n", ch);
}
else
{
printf("输入的不是大写或者小写字母\n");
}
return 0;
}
#include<stdio.h>
void main()
{
char a;
printf("请输入一个字母:");
scanf("%c", &a);
if (a <= 91) //对应ASCII表判断输入字母的ASCII值,大写字母A~Z的ASCII值为65~91
{
a = a + 32; //字母a~z的ASCII值为97~123,则给该字符加32之后,他的ASCII值变为对应的小写字母的ASCII值
printf("该子母的小写形式为:%c\n", a);
}
else
{
a = a - 32; //同大写变小写的ASCII值的转换
printf("该子母的大写形式为:%c\n", a);
}
}
以上两种都是通过ASCII码进行实现的。
1)考虑到低四位完全相同 只用互换高四位的第六位就可以实现大小写互换 (2)互换高四位的某一位而不改变低四位,我们联想到位运算中的按位异或^ 关于按位异或 详见按位异或 (3)由按位异或的知识,我们可以寻找一个数,使得任意的一个八位二进制数与它进行异或操作后,高四位的第六位01取反,低四位不变 回顾我们的目标 假如把'A'变为'a' 我们需要把01000001变为01100001,也就是把第六位的0变为1 我们找到这个数了!它的二进制是00100000 十进制是32 01000001^00100000=01100001
看一下代码:
#include<stdio.h>
int main()
{
int i = 0;
char arr[100];
gets_s(arr);
for (i = 0; arr[i] != '\0'; i++)
{
if ((arr[i] >= 'A') && (arr[i] <= 'Z') || (arr[i] >= 'a') && (arr[i] <= 'z'))
{
arr[i] ^= 32;
}
}
printf("%s",arr);
return 0;
}
#include <iostream>
#include <ctype.h>// toupper tolower
#include <cstring>
using namespace std;
int main()
{
char a[100];
int n, i;
cin >> a;
n = strlen(a);
for (i = 0; i < n; i++)
{
a[i] = toupper(a[i]);//小写转大写
}
cout << a << endl;
for (i = 0; i < n; i++)
{
a[i] = tolower(a[i]);//大写转小写字母(只能是对字母有效)
}
cout << a << endl;
return 0;
}
这便可以实现大小写字母的转换。