免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 9125 | 回复: 27
打印 上一主题 下一主题

C语言求字符串分割的函数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-06-11 19:40 |只看该作者 |倒序浏览
有一个字符串:ABBBCBBBD,分隔符是BBB或者其他字符串,希望能拆出:A C D
本来想自己写的,写不下去了,求大侠帮忙啊

论坛徽章:
0
2 [报告]
发表于 2012-06-11 21:06 |只看该作者
试试   sscanf   

论坛徽章:
0
3 [报告]
发表于 2012-06-11 21:36 |只看该作者
直接搞也很简单的啊。

论坛徽章:
0
4 [报告]
发表于 2012-06-11 21:51 |只看该作者
是不是,用以个循环遍历,然后
if(A[i]==A[i+1])
    A[i]=A[i+1]=' ';

论坛徽章:
0
5 [报告]
发表于 2012-06-11 22:01 |只看该作者
本帖最后由 thankcs 于 2012-06-11 22:02 编辑

给你一个我写的吧,虽然代码写得很烂。但能用!
/*
        功能: 分割联系人定义列表
        日期: 2012/06/07
        输入:
                        source:  自定义宏值
                        keystr:         分割符
        输出:
           connectlist:  自定义联系人列表
*/
static int GetStrList(char *source, char *keystr, char connectlist[_MAX_CONNECT_][_MAX_CONNECT_LEN_])
{
        char source_temp[512 +1];
        char exchage_temp[512 +1];
        char exchage_temp2[512 +1];
        int iCount =0;
        int offset = strlen(keystr);
        char *point = NULL;
       
        TLogL(LEVEL3,__FILE__, __LINE__, "%s>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>", __FUNCTION__);
       
        memset(source_temp, 0, sizeof(source_temp));
        strcpy(source_temp, source);
       
        while( (point = strstr(source_temp, keystr) ))
        {
                memset(exchage_temp, 0, sizeof(exchage_temp));
        strcpy(exchage_temp, source_temp);
        memset(exchage_temp2, 0, sizeof(exchage_temp2));
        strcpy(exchage_temp2,point+offset );
        memset(source_temp, 0, sizeof(source_temp));
        strcpy(source_temp, exchage_temp2);
        memcpy(connectlist[iCount], exchage_temp, strlen(exchage_temp)-strlen(source_temp)-offset);
        iCount++;
    }
   
    if ( strlen(source_temp) )
            strcpy(connectlist[iCount], source_temp);
   
           TLogL(LEVEL3,__FILE__, __LINE__, "%s<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<", __FUNCTION__);
        return SUCCESS;
}

论坛徽章:
0
6 [报告]
发表于 2012-06-11 22:22 |只看该作者
olivehht 发表于 2012-06-11 19:40
有一个字符串:ABBBCBBBD,分隔符是BBB或者其他字符串,希望能拆出:A C D
本来想自己写的,写不下去了,求 ...
  1. const int PatLength = 300;
  2. int nextVal[PatLength];

  3. void getNext(char *pat) {
  4.     int i = 0, j = -1;
  5.     nextVal[0] = -1;
  6.     while(pat[i]) {
  7.         if(j == -1 || pat[i] == pat[j]) {
  8.             ++i, ++j;
  9.             if(pat[i] == pat[j]) {
  10.                 nextVal[i] = nextVal[j];
  11.             } else {
  12.                 nextVal[i] = j;
  13.             }
  14.         } else {
  15.             j = nextVal[j];
  16.         }
  17.     }
  18. }
  19. //start表示从哪个字符之后开始寻找匹配
  20. //-1表示从第一个字行开始,0表示第一个字符之后,依次类推
  21. int KMP(char *str, char *pat, int start) {
  22.     int i = start, j = -1;
  23.     while(j == -1 || (str[i] && pat[j])) {
  24.         if(j == -1 || str[i] == pat[j]) {
  25.             ++i, ++j;
  26.         } else {
  27.             j = nextVal[j];
  28.         }
  29.     }
  30.     if(!pat[j]) return i - j;
  31.     return -1;
  32. }
复制代码
表示这个KMP代码也可以用的……多次调用KMP就行了。

论坛徽章:
0
7 [报告]
发表于 2012-06-12 08:46 |只看该作者
KMP。。。。。

论坛徽章:
0
8 [报告]
发表于 2012-06-12 11:26 |只看该作者
库函数 strtok,自己去查用法吧

论坛徽章:
3
寅虎
日期:2013-11-27 07:53:29申猴
日期:2014-09-12 09:24:152015年迎新春徽章
日期:2015-03-04 09:48:31
9 [报告]
发表于 2012-06-12 13:16 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
10 [报告]
发表于 2012-06-12 13:23 |只看该作者
what would acts while the input string is

aBBBBbBBBBBBc
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP