如何用CC++代码实现递归方法栈逆序字符串的示例?
- 内容介绍
- 文章标签
- 相关推荐
本文共计262个文字,预计阅读时间需要2分钟。
C语言实现递归和栈逆序字符串的例子:
递归函数调用模型,逆序方法:cvoid reverse(char *buf){ char *p=buf; if (p==NULL) { return; } // 递归结束条件 if (*p=='\0') { return; } // 递归调用 reverse(p + 1); // 在字符串中逆序插入字符 while (*p) { p++; } p--; // 回到字符串末尾 while (*p !='\0') { char temp=*p; *p=*buf; *buf=temp; p--; buf++; }}
C/C++ 实现递归和栈逆序字符串的实例
递归函数调用模型
逆序方法
void revers(char *buf){ char *p = buf; if (p == NULL) { return; } //递归结束条件 if (*p == '\0') { return; } //递归调用 revers(p + 1); //在字符串的结尾追加n个字符 strncat(buf_g, p, 1); }
调用
int main(int argc, const char * argv[]) { char *c = "abcde"; //清空 memset(buf_g, 0, sizeof(buf_g)); revers(c); printf("%s\n",buf_g); return 0; }
以上就是C/C++ 实现递归和栈逆序字符串的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文共计262个文字,预计阅读时间需要2分钟。
C语言实现递归和栈逆序字符串的例子:
递归函数调用模型,逆序方法:cvoid reverse(char *buf){ char *p=buf; if (p==NULL) { return; } // 递归结束条件 if (*p=='\0') { return; } // 递归调用 reverse(p + 1); // 在字符串中逆序插入字符 while (*p) { p++; } p--; // 回到字符串末尾 while (*p !='\0') { char temp=*p; *p=*buf; *buf=temp; p--; buf++; }}
C/C++ 实现递归和栈逆序字符串的实例
递归函数调用模型
逆序方法
void revers(char *buf){ char *p = buf; if (p == NULL) { return; } //递归结束条件 if (*p == '\0') { return; } //递归调用 revers(p + 1); //在字符串的结尾追加n个字符 strncat(buf_g, p, 1); }
调用
int main(int argc, const char * argv[]) { char *c = "abcde"; //清空 memset(buf_g, 0, sizeof(buf_g)); revers(c); printf("%s\n",buf_g); return 0; }
以上就是C/C++ 实现递归和栈逆序字符串的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

