gpt4 book ai didi

c - 在 C 中处理 ASCII 字母

转载 作者:行者123 更新时间:2023-11-30 20:20:53 25 4
gpt4 key购买 nike

#include <stdio.h>
#include <string.h>

int main()
{
int key;
char line[500];
char ch = '\0';
int i = 0;

printf("Enter key: ");
scanf("%d", &key);
getchar();

printf("Enter line: ");

while(ch != '\n')
{
ch = getchar();
line[i] = ch;
i++;
}

int length = i;
int k = 0;
char temp[length];

for(i = 0; i < length; i++)
{

if((int)line[i] >= 65 && (int)line[i] <= 90)
{
temp[k++] = (int)line[i] + key;
} else if((int)line[i] >= 97 && (int)line[i] <= 122){
temp[k++] = (int)line[i] + key;
} else {
temp[k++] = line[i];
}
}

printf("\n");

for(i = 0; i < length; i++)
{
printf("%c", temp[i]);
}
}

到目前为止我所做的是将字符转换为另一种字符。例如,如果我输入“abc ABC”,并且添加值(int key)是3,那么它应该打印出“def DEF”。

这工作得很好,但我想进一步实现的是如果字符超出范围则倒回该字符。例如,如果我输入“XYZ”并且相加值为3,则应该打印出“ABC”,而不是“[]”。我可以获得有关如何解决此问题的任何帮助或建议吗?谢谢..

最佳答案

首先,当我看到

if((int)line[i] >= 65 && (int)line[i] <= 90)

我的第一 react 是,“65 和 90 是什么意思?”嗯,我知道,但是,这些数字对你来说是不必要的麻烦,对读者来说也是不必要的麻烦。所以就说吧

if(line[i] >= 'A' && line[i] <= 'Z')

相反。在C语言中,像'A'这样的字符常量的值是机器字符集中的字符值,或者ASCII中的65。 (我还删除了一些不必要的强制转换。)

接下来,解决问题的一种强力方法是仅检查溢出:

if(line[i] >= 'A' && line[i] <= 'Z')
{
temp[k] = line[i] + key;
if(temp[k] > 'Z')
temp[k] -= 26;
k++;
}

由于在完成之前我必须使用 temp[k] 做几件事,所以我将 k++ 移到了最后。

您可以对 a-z 情况使用类似的代码。

如果你想让程序更通用,key也有可能为负数。在这种情况下,您还必须担心“小于”A 的字母。您可以像这样扩展代码:

if(line[i] >= 'A' && line[i] <= 'Z')
{
temp[k] = line[i] + key;
if(temp[k] > 'Z')
temp[k] -= 26;
else if(temp[k] < 'A')
temp[k] += 26;
k++;
}

同样,您需要对 a-z 情况重复此操作。

现在,执行此操作的非暴力方法是认识到我们在这里执行的“环绕”算术也称为“模”算术,因为它与“模”或“余数”相关运算符,%。因此,如果您了解 % 的工作原理,您可以编写如下代码:

if(line[i] >= 'A' && line[i] <= 'Z')
{
int c = line[i] - 'A';
c = (c + key) % 26;
temp[k++] = c + 'A';
}

这仍然不是完全简单,因为我们必须从像“Y”这样的字母,到它在字母表中从 0 开始的位置 (25),再到它的移位值 (28,假设有一个 of 3),为其“模”值 {2},然后最后返回到像“B”这样的字母。

或者,更详细地说,大写字母在 ASCII 中是 65 到 90。因此,我们减去 65 即可得到 0-25 范围内的数字。一旦我们在 0-25 范围内,我们就可以使用模运算,因为 % 26 基本上意味着“仅在 0 - 25 范围内的整数”。最后,当我们完成模数运算后,我们再次添加 65,以恢复到实际字母的 65-90 范围。 (我们不是减去并加上 65,而是减去并加上 'A',因为它是相同的值,但更清晰。)

而且,我仍然只显示大写字母的代码;您还必须为 a-z 情况重复此代码。

关于c - 在 C 中处理 ASCII 字母,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44486104/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com