- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我真的不明白最后一个 while 循环在做什么,谁能解释一下?
void reverse(char *str) {
char * end = str;
char tmp;
if (str) {
while (*end) {
++end;
}
--end;
while (str < end) {
tmp = *str;
*str++ = *end;
*end-- = tmp;
}
}
}
谁能带我看一下“你好”这个例子?
最佳答案
此代码背后的基本思想是分两步进行:
第一遍由以下逻辑给出:
char *end = str;
while (*end) {
++end;
}
--end;
此 while
循环以指向字符串开头的 end
指针开始。然后,它不断地将 end
指针向前移动一步,直到循环条件 *end
不再计算为真。因为 C 字符串以 null 终止,所以只要 end
指针指向字符串中间的某处而不是字符串末尾的 null 终止符,循环条件就会计算为真。因此,当此循环结束时,end
指针将一直走到字符串的末尾并停在空终止符处。然后我们执行 --end
来备份指针一步。此时,end
指针指向字符串中的最后一个字符。这是一个带有“你好:”的例子
H e l l o
^ ^
| |
str end
现在我们有了这个 end
指针,我们实际上运行逻辑来反转字符串。这是由这段代码给出的:
while (str < end) {
tmp = *str;
*str++ = *end;
*end-- = tmp;
}
这段代码背后的想法是,在字符串的起始指针和结束指针相互交叉之前,我们交换它们指向的值,然后将两个指针向内移向彼此。如果我们通过稍微更冗长的方式将其重写为等价物
while (str < end) {
tmp = *str;
*str = *end;
*end = tmp;
++str;
--end;
}
然后可能更容易理解它是如何工作的。这个修改后的循环的前三行交换开始和结束指针指向的值,接下来的两行将指针向内移动。这是一个例子:
H e l l o
^ ^
| |
str end
o e l l H
^ ^
| |
str end
o l l e H
^
|
str end
此时,两个指针相遇,我们就正确地反转了字符串。
请注意,这里我们必须考虑一个不寻常的边缘情况,这就是当字符串为空字符串时会发生的情况。如果发生这种情况,那么第一个循环的行为会有点奇怪。特别是这段代码:
char *end = str;
while (*end) {
++end;
}
--end;
永远不会执行循环体,因为 end
指针将从指向空终止符开始。因此,该循环什么都不做,我们最终在字符串开始前返回 end
一个步骤! 这是一个无效指针,取消引用它会产生未定义的结果。但幸运的是,在这种情况下,什么也没有发生,因为反转字符串的循环有这样的条件:
while (str < end)
如果 end
是字符串开始前的一步,则立即为 false,因此什么也不会发生。
希望这对您有所帮助!
关于c - 解释这个 C 代码来反转一个字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5072806/
我正在尝试将我在本文档中阅读的内容付诸实践: https://sar.informatik.hu-berlin.de/research/publications/SAR-PR-2006-05/SAR-
我一直在尝试编写一个可以改变这个的 terraform 表达式: subnets = { my_subnet_1 = { nsg = "my_nsg_1", ad
我有一个HashMap,它将两个字符串转换为单词,然后将单词添加到 map 中。我拥有它,以便一个键可以指向多个值。现在我想创建一个循环来反转表,以便所有值都指向键。不要为一个指向多个逆值的键而烦恼。
我对 ~ 运算符有点困惑。代码如下: a = 1 ~a #-2 b = 15 ~b #-16 ~ 是如何工作的? 我想,~a 会是这样的: 0001 = a 1110 = ~a 为什么不呢? 最佳
如果执行 ResourceManager.GetString(Key),您可以获取资源中某个项目的值。有没有一种方法可以进行反向查找以从给定值的资源中获取 key (本质上是反翻译)? 最佳答案 您应
我在 R 中编写了一个代码来反转一个数字。但是我得到了 inf作为输出。 digit0){ rev_num=rev_num*10 + digit %% 10 digit=digit / 10 }
这个问题已经有答案了: Invert keys and values of the original dictionary (3 个回答) 已关闭 9 年前。 我正在寻找在 python 上转置一本字
所以我试图反转我当前制作的形状的输出。我想知道我应该扭转这种情况吗?我尝试更改变量“a”和“c”的值,最终陷入无限循环。 class IRT { public static void main
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: PHP mysql_real_escape_string() -> stripslashes() leavi
从 Wordpress 模板中提取一些预先存在的代码来绘制椭圆阴影。阴影呈椭圆形向下辐射。只有椭圆的下半部分可见,从而形成底部阴影效果。 我只是想“反转”椭圆的“阴影效果”,以便只有阴影的顶部 一半可
我有一个函数应该找到两个弧度的中间 function mrad(rb,ra){return (rb+ra)/2;} 但有时,当我用 Math.sin 和 Math.cos 绘制 x 和 y 时,这两个
给定此代码(http://jsfiddle.net/bzf1mkx5/) .intern { -webkit-animation: in 1s 1 reverse forwards; } .i
我对 ~ 运算符有点困惑。代码如下: a = 1 ~a #-2 b = 15 ~b #-16 ~ 是如何工作的? 我想,~a 会是这样的: 0001 = a 1110 = ~a 为什么不呢? 最佳
我需要以相反的顺序从列表中提取项目(从最后一个条目到第一个)。我设法得到了所有元素,但是,从第一个到最后一个。这是我正在使用的部分代码: 该列表位于不同的网站集上。 using (SPSit
由于一些证书问题,我不得不写 ServicePointManager.ServerCertificateValidationCallback += (sender, certificate, chai
是否有一个函数接受一个函数列表和一个输入,并输出一个对输入进行操作的函数列表? 所以像 map,但倒退: >>>map(lambda x: 2*x,[1,2,3,4,5,6,7,8,9]) [2, 4
考虑下表团队消息: 15:10 | Peter | I'm off to the store, call my mobile phone if you need me. 15:11 | Susy |
算法如下: int encryption(int a, int b) { short int c, c2; uint8_t d; c = a ^ b; c2 = c;
我正在寻找一种方法来逆转 a CRC32 checksum .周围有解决方案,但它们要么是 badly written , extremely technical和/或 in Assembly .汇编
使用批处理文件,处理所有在文件名或扩展名中共享字符串的文件就足够简单了,例如: FOR /R %F IN (*.EXE) DO @ECHO %F 但是,如果我想反转文件集的含义怎么办?比如,处理所有不
我是一名优秀的程序员,十分优秀!