- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
#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/
双引号的 ASCII 数字是多少? (") 另外,是否有指向任何地方的列表的链接? 最后,如何进入C族(尤其是C#) 最佳答案 引号的 ASCII 码是 34。 (好吧,严格来说,它不是真正的引号,而
考虑一台计算机,它有一个字节可寻址内存,根据大端方案组织成 32 位字。程序读取在键盘上输入的 ASCII 字符并将它们存储在连续的字节位置,从位置 1000 开始。在输入名称“johnson”后显示
\x20 下的大多数 ASCII 代码似乎完全过时了。他们今天有没有使用?它们是否可以被视为“可供抢夺”,还是最好避免它们? 我需要一个分隔符来将“行”分组在一起,为此目的选择其中一个肯定会很好。 来
非字母数字或标点符号的字符称为不可打印: Codes 20hex to 7Ehex, known as the printable characters 那么为什么是例如005 可表示(并由 club
在我的一次面试中,面试官问我为什么在 ASCII 表中大写字母在小写字母之前,我在 google.com 上搜索但没有找到,谁能给我答案?多谢! 最佳答案 我只是猜测,但我想这是因为最早的字符集根本没
由于编码原因可能会让您感到恐惧(我不好意思说),我需要在单个字符串中存储多个文本项。 我将使用一个字符来分隔它们。 哪个字符最适合用于此目的,即哪个字符最不可能出现在文本中?必须是可打印的,并且可能小
我的代码将一大堆文本数据传递给负责存储这些数据的遗留库。但是,它倾向于删除尾随空格。当我读回数据时,这是一个问题。由于我无法更改遗留代码,因此我考虑用一些不常见的 ASCII 字符替换所有空格。当我读
我正在检查井号 (£) 的 ASCII 值。我找到了多个答案: http://www.ascii-code.com/说 A3 = 163 是井号的 ASCII 值。 http://www.asciit
我们好像只用了'\0'(null),'\a'(bell),'\b'(backspace),'\t'(水平制表符),'\n'(line fee) ,'\r'(回车),'\v'(垂直制表符),'\e'(转
当我查看 rust ASCII operations感觉之间存在一致性问题 is_lowercase/is_uppercase: pub fn is_uppercase(&self) -> bool
我一直假设 ASCII 码的范围是 0 到 255。昨晚我不得不处理一个我认为是下划线但结果是 Chr(8230) 的字符。三个类似下划线的小点。这是在 AutoHotKey 脚本中。问题已解决,但给
也许我在使用 Google 方面做得很糟糕,但这些规范适用于 Bencoding继续引用称为“十进制 ASCII”的东西,这让我认为它与常规 ASCII 不同。有人能解释一下吗? 最佳答案 base明
我正在尝试将小字符串转换为它们各自的 ascii 十进制值。就像将字符串“Ag”转换为“065103”一样。 我尝试使用 integer_variable : Integer := Integer'V
我想使用程序或图形库将图像转换为 ASCII 艺术,但我想指定要使用的调色板(符号)。所以基本上我想要一个图像,它从某个字母 A 呈现为文本,它是完整 ASCII 表的子集,例如 A := {a,b,
是否可以使用 Graphviz 绘制 ASCII 图表? 类似的事情: digraph { this -> is this -> a a -> test } 给出了不想要的结果。 相反,我
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
如何将 Žvaigždės aukštybėj užges 或 äüöÖÜÄ 之类的字符串转换为 Zvaigzdes aukstybej uzges 或 auoOUA,分别使用 Bash? 基本上我只
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How would you convert from ASCII to Hex by character i
我有一个成员搜索功能,您可以在其中提供部分姓名,返回的内容应该是至少具有与该输入匹配的用户名、名字或姓氏之一的所有成员。这里的问题是某些名称具有“奇怪”的字符,例如 Renée 中的 é 并且用户不想
我有文件名“abc张.xlsx”,其中包含某种非 ASCII 字符编码,我想删除所有非 ASCII 字符以将其重命名为“abc.xlsx”。 这是我尝试过的: import os import str
我是一名优秀的程序员,十分优秀!