【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | strncat 函数 )
【摘要】
文章目录
一、strncat 字符串连接函数二、借助 递归函数操作 逆序字符串操作三、完整代码示例
一、strncat 字符串连接函数
strncat 函数 : 将...
一、strncat 字符串连接函数
strncat
函数 : 将 const char *src
指针指向的 size_t n
个字符 , 连接到 char *dest
字符串后面 ;
#include <string.h>
char * strncat(char *dest, const char *src, size_t n);
- 1
- 2
注意 : 上述操作是 const char *src
字符串 的 首字符 , 覆盖 char *dest
字符串的 \0
字符 ;
二、借助 递归函数操作 逆序字符串操作
在上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序打印字符串 | 递归要素 | 递归停止条件 | 递归操作 ) 的基础上 , 保存逆序结果 ;
递归返回后 , 可以逆序打印字符串中的字符 ;
// 打印出栈的字符
// 注意 : 该打印操作是 递归停止条件达成后
// 逐个出栈打印
printf("*str = %c\n", *str);
- 1
- 2
- 3
- 4
此处只需要将该 字符 保存到 全局变量即可 ;
使用字符串连接函数 strncat
逐个字符拼接字符串 ;
// 连接字符串 , 从 '\0' 位置处开始覆盖
strncat(str_buf, str, 1);
- 1
- 2
三、完整代码示例
完整代码示例 :
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/*
* 定义全局变量, 用于保存翻转后的字符串
*/
char str_buf[1024];
/*
* 通过递归方式 , 逆向遍历字符串
* 将 递归遍历 结果存入 全局变量中
* 递归指针 作 函数参数
*/
void str_inverse(char *str)
{
// 验证函数形参指针合法性
if(str == NULL)
{
return;
}
// 递归停止条件
if(*str == '\0')
{
return;
}
// 递归操作
// 该递归操作会逐步 将 字符串 从开始位置 入栈
// 直到递归到 '\0' 位置时 , 才开始出栈
// 此处是递归点
// 递归操作执行到这里 , 开始一直递归
// 递归结束后 , 依次执行下面的代码
str_inverse(str + 1);
// 打印出栈的字符
// 注意 : 该打印操作是 递归停止条件达成后
// 逐个出栈打印
printf("*str = %c\n", *str);
// 拷贝一个字符到全局变量中
//strncpy(str_buf, str, 1);
// 连接字符串 , 从 '\0' 位置处开始覆盖
strncat(str_buf, str, 1);
}
int main()
{
// 存在如下字符串, 求下面字符串 "abc" 出现次数
char *str = "sdh";
// 初始化 str_buf 全局变量
memset(str_buf, 0, sizeof (str_buf));
// 字符串翻转
str_inverse(str);
// 打印字符串翻转结果
printf("str_buf = %s\n", str_buf);
// 命令行不要退出
system("pause");
return 0;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
执行结果 :
*str = h
*str = d
*str = s
str_buf = hds
请按任意键继续. . .
- 1
- 2
- 3
- 4
- 5
文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。
原文链接:hanshuliang.blog.csdn.net/article/details/121526357
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)