【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | strncat 函数 )

2023-03-29 21:27:06 浏览数 (1)

文章目录

  • 一、strncat 字符串连接函数
  • 二、借助 递归函数操作 逆序字符串操作
  • 三、完整代码示例

一、strncat 字符串连接函数


strncat 函数 : 将 const char *src 指针指向的 size_t n 个字符 , 连接到 char *dest 字符串后面 ;

代码语言:javascript复制
#include <string.h>
char * strncat(char *dest, const char *src, size_t n);

注意 : 上述操作是 const char *src 字符串 的 首字符 , 覆盖 char *dest 字符串的 字符 ;

二、借助 递归函数操作 逆序字符串操作


在上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序打印字符串 | 递归要素 | 递归停止条件 | 递归操作 ) 的基础上 , 保存逆序结果 ;

递归返回后 , 可以逆序打印字符串中的字符 ;

代码语言:javascript复制
    // 打印出栈的字符
    // 注意 : 该打印操作是 递归停止条件达成后
    //       逐个出栈打印
    printf("*str = %cn", *str);

此处只需要将该 字符 保存到 全局变量即可 ;

使用字符串连接函数 strncat 逐个字符拼接字符串 ;

代码语言:javascript复制
    // 连接字符串 , 从 '' 位置处开始覆盖
    strncat(str_buf, str, 1);

三、完整代码示例


完整代码示例 :

代码语言:javascript复制
#include <stdio.h>
#include <stdlib.h>
#include <string.h>


/*
 * 定义全局变量, 用于保存翻转后的字符串
 */
char str_buf[1024];

/*
 * 通过递归方式 , 逆向遍历字符串
 * 将 递归遍历 结果存入 全局变量中
 * 递归指针 作 函数参数
 */
void str_inverse(char *str)
{
    // 验证函数形参指针合法性
    if(str == NULL)
    {
        return;
    }

    // 递归停止条件
    if(*str == '')
    {
        return;
    }

    // 递归操作
    // 该递归操作会逐步 将 字符串 从开始位置 入栈
    // 直到递归到 '' 位置时 , 才开始出栈
    // 此处是递归点
    // 递归操作执行到这里 , 开始一直递归
    // 递归结束后 , 依次执行下面的代码
    str_inverse(str   1);

    // 打印出栈的字符
    // 注意 : 该打印操作是 递归停止条件达成后
    //       逐个出栈打印
    printf("*str = %cn", *str);

    // 拷贝一个字符到全局变量中
    //strncpy(str_buf, str, 1);

    // 连接字符串 , 从 '' 位置处开始覆盖
    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 = %sn", str_buf);

    // 命令行不要退出
    system("pause");
    return 0;
}

执行结果 :

代码语言:javascript复制
*str = h
*str = d
*str = s
str_buf = hds
请按任意键继续. . .

0 人点赞