为什么此代码打印"olleH"?
Why does this code print "olleH"?
为什么这个程序打印"olleH"?
这个程序似乎什么都不会打印——但我似乎不明白递归是如何工作的。
#include "stdafx.h"
#include <iostream>
#include <string>
using namespace std;
void function(string, int, int);
int main()
{
string mystr = "Hello";
cout << mystr << endl;
function(mystr, 0, mystr.size());
system("pause");
return 0;
}
void function(string str, int pos, int size)
{
if (pos < size)
{
cout << str[pos];
function(str, pos + 1, size);
}
}
两件事:首先,术语:您编写的函数声明返回void
而不是string
,但确实打印了一个字符串。其次,当我运行它时,你发布的代码会打印出"Hello"。我假设你的问题是,如果你在function()
:中切换这两行的顺序,为什么会打印"olleH"
cout << str[pos]; //prints "Hello"
function(str, pos + 1, size);
相比:
function(str, pos + 1, size);//prints "olleH"
cout << str[pos];
正如您所说,这是递归。要理解这一点,您需要记住函数的调用顺序和它们返回的相反顺序,将控制权传递给调用它们的函数。对function()
的第一个调用(pos
位于字符串的开头)返回最后一个,递归调用在返回之前返回,最里面的函数调用(pos
位于字符串的末尾)是第一个完全运行的函数。(这是因为递归调用仅为if (pos < size)
,并且此限制对于防止无限循环非常重要)。因此,在以pos
开头的对function()
的第一次调用中,如果它在再次调用function()
以写入字符串的其余部分之前写入第一个字符,则字符串将按顺序排列。如果您在写入字符串的其余部分之后写入第一个字符,那么它将按相反的顺序,就像在两种不同的情况下一样。
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 打印数字图案
- Log4cpp:以UTC/GMT时区打印日期
- 为什么此代码打印"olleH"?