专栏首页TheOneGIS空间站C++中字符串的分割

C++中字符串的分割

坚持走下去,坚持下去!男子汉要能忍! —题记

下面开始正题,C++中字符串的分割。 1. 使用strtok函数进行字符串的分割 2. 使用stringstream类配合getline函数进行字符串的分割 3. 使用STL的find函数以及字符串类的substr函数进行字符串分割


strtok函数介绍: 头文件:#include <string.h>

定义函数:char * strtok(char *s, const char *delim);

函数说明:strtok()用来将字符串分割成一个个片段。参数s 指向欲分割的字符串,参数delim 则为分割字符串,当strtok()在参数s 的字符串中发现到参数delim 的分割字符时则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s 字符串,往后的调用则将参数s 设置成NULL。每次调用成功则返回下一个分割后的字符串指针。

返回值:返回下一个分割后的字符串指针,如果已无从分割则返回NULL。

void splitWithStrtok(const char* str, const char* delim, vector<string>& ret)
{
    char* strcopy = new char[strlen(str) + 1];
    strcpy(strcopy, str);
    char *word = strtok(strcopy, delim);
    ret.push_back(word);
    while (word = strtok(nullptr, delim))
        ret.push_back(word);
    delete[] strcopy;
}

getline函数介绍: 头文件:#include <string.h>

函数原型:istream& getline (istream& is, string& str, char delim);

函数说明:从is输入流中提取依次字符存存放到str中直到遇到delim字符或者换行符’\n’。

void splitWithStringStream(const string& str, char delim, vector<string>& ret)
{
    stringstream ss(str);
    string s;
    while (getline(ss, s, delim))
    {
        ret.push_back(s);
    }
}

最后一种方法就是便利字符串依次找分隔符,找到了就提取前一个分隔符到当前分隔符之间的子串。

void splitWithSTLFind(const string& str, const string& delim, vector<string>& ret)
{
    size_t front = 0;
    size_t back = str.find_first_of(delim, front);
    while (back != string::npos)
    {
        ret.push_back(str.substr(front, back - front));
        front = back + 1;
        back = str.find_first_of(delim, front);
    }
    if (back - front > 0)
    {
        ret.push_back(str.substr(front, back - front));
    }
}

最后,我们写一个函数测试一下吧!

int main()
{
    const char* str = "3.14,5.0,12,0";
    const char* delim = ",";
    vector<string> vetnum;

    splitWithStrtok(str, delim, vetnum);
    cout << "使用strtok函数进行字符串分割:" << '\n';
    for (auto iter = vetnum.begin(); iter != vetnum.end(); iter++)
        cout << *iter << '\n';

    vetnum.clear();
    splitWithSTLFind(str, delim, vetnum);
    cout << "使用STL的Find方法进行字符串分割:" << '\n';
    for (auto iter = vetnum.begin(); iter != vetnum.end(); iter++)
        cout << *iter << '\n';

    vetnum.clear();
    splitWithStringStream(str, delim[0], vetnum);
    cout << "使用stringstream类进行字符串分割:" << '\n';
    for (auto iter = vetnum.begin(); iter != vetnum.end(); iter++)
        cout << *iter << '\n';
    _CrtDumpMemoryLeaks();
    return 0;
}

运行结果:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • cfE. Ehab and a component choosing problem(贪心)

    证明:因为我们是在保证分数最大的情况下才去最大化\(k\),一个很经典的结论是单独选择一个权值最大的联通块得到的分数一定是最大的,然后我们这时我们才去考虑最大化...

    attack
  • LeetCode 80 Remove Duplicates from Sorted Array II

    和 LeetCode 26 Remove Duplicates from Sorted Array 这道题比较类似。 定义变量 k,表示待修改的元素位置,默认为...

    一份执着✘
  • GuavaCache学习笔记一:自定义LRU算法的缓存实现

    今天在看GuavaCache缓存相关的源码,这里想到先自己手动实现一个LRU算法。于是乎便想到LinkedHashMap和LinkedList+HashMap,...

    一枝花算不算浪漫
  • 《统计学习方法》笔记九 EM算法及其推广

    EM算法是一种迭代算法,用于含有隐变量的概率模型参数的极大似然估计或极大后验概率估计。迭代由

    闪电gogogo
  • BZOJ4513: [Sdoi2016]储能表(数位dp)

    \[ f_{i,j}= \begin{aligned} i\oplus j &\left( i\oplus j >k\right) \\ 0 ...

    attack
  • BZOJ4650: [Noi2016]优秀的拆分(hash 调和级数)

    考虑怎么优化。 显然我们只要找出所有形如\(AA\)的字符串就行了,设\(pre[i]\)表示以\(i\)为端点,向前的所有\(AA\)的数量,\(suf[i]...

    attack
  • BZOJ4598: [Sdoi2016]模式字符串(点分治 hash)

    设\(up[i]\)表示\(dep \% M = i\)的从下往上恰好与前\(i\)位匹配的个数

    attack
  • cfD. Ehab and another another xor problem(思维)

    系统中有两个数\((a, b)\),请使用\(62\)以内次询问来确定出\((a, b)\)

    attack
  • 问题解决思想方法论: 分而治之 (Divide and Conquer)

    所谓“分而治之” 就是把一个复杂的算法问题按一定的“分解”方法分为等价的规模较小的若干部分,然后逐个解决,分别找出各部分的解,把各部分的解组成整个问题的解,这种...

    一个会写诗的程序员
  • BZOJ4602: [Sdoi2016]齿轮(并查集 启发式合并)

    那么我们预处理出\(val[i]\)表示的是\(i\)节点所在的联通块根节点转了\(1\)圈,该节点会转多少圈

    attack

扫码关注云+社区

领取腾讯云代金券