C语言自定义函数实现以特定字符分割字符串

原理概括

  • 双指针法

原理图解

核心代码

/******************************************************************************
 * 负 责 人 : 易齐
 * 创建日期 :2022-01-22 13:56:55
 * 函数功能 : 以 特定字符 分隔字符串
 * 输入参数 : argv: 装分隔好的字符串的指针数组 ,str: 需要分隔的字符串 , separator:分隔字符
 * 输出参数 : 分隔好后 指针数组 的长度
 * 返 回 值 :无
 * 调用关系 :无
 * 其    它 :无
 ******************************************************************************/
int split(char *argv[], char *str, char separator)
{
    //定义双指针
    char *start_c = str;
    char *end_c = str;
    //定义分隔结果编号
    int index = 0;

    //反复遍历
    while (*end_c != '\0')
    {
        //如果遇到了分隔符
        if (*end_c == separator)
        {
            //分隔符连续出现
            if (start_c == end_c)
            {
                argv[index] = NULL;
            }
            //分隔符中间有字符
            else
            {
                argv[index] = start_c;
            }
            //将分隔符置换为结束符
            *end_c = '\0';
            index++;
            start_c = end_c + 1;
        }
        end_c++;
    }

    //处理最后一次遍历结果
    if (start_c != end_c)
    {
        argv[index] = start_c;
    }
    //处理最后一次遍历结果 如果两个指针位置一直,说明数据无效
    else
    {
        index--;
    }

    //返回分隔后数组的长度
    return index;
}

测试代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define GPRMC_MAX_DATA_NUMS 14

int split(char *argv[], char *str, char separator);

int main()
{
    //   $GNRMC,,V,,,,,,,,,,N,V*37
    char str[] = "$GNRMC,,V,,,,,,,,,,N,";
    char *argv[GPRMC_MAX_DATA_NUMS];

    int len = split(argv, str, ',');

    int i = 0;
    for (i = 0; i <= len; i++)
    {
        printf("=%s=\n", argv[i]);
    }

    return 0;
}

/******************************************************************************
 * 负 责 人 : 易齐
 * 创建日期 :2022-01-22 13:56:55
 * 函数功能 : 以 特定字符 分隔字符串
 * 输入参数 : 装分隔好的字符串的指针数组 ,需要分隔的字符串 , 分隔字符
 * 输出参数 : 分隔好后 指针数组 的长度
 * 返 回 值 :无
 * 调用关系 :无
 * 其    它 :无
 ******************************************************************************/
int split(char *argv[], char *str, char separator)
{
    //定义双指针
    char *start_c = str;
    char *end_c = str;
    //定义分隔结果编号
    int index = 0;

    //反复遍历
    while (*end_c != '\0')
    {
        //如果遇到了分隔符
        if (*end_c == separator)
        {
            //分隔符连续出现
            if (start_c == end_c)
            {
                argv[index] = NULL;
            }
            //分隔符中间有字符
            else
            {
                argv[index] = start_c;
            }
            //将分隔符置换为结束符
            *end_c = '\0';
            index++;
            start_c = end_c + 1;
        }
        end_c++;
    }

    //处理最后一次遍历结果
    if (start_c != end_c)
    {
        argv[index] = start_c;
    }
    //处理最后一次遍历结果 如果两个指针位置一直,说明数据无效
    else
    {
        index--;
    }

    //返回分隔后数组的长度
    return index;
}

测试结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

super码王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值