zoukankan      html  css  js  c++  java
  • C提高_day03_两个辅助指针变量挖字符串(强化1)

    #include <stdlib.h>
    #include <string.h>
    #include <stdio.h>
    
    //两个辅助指针变量挖字符串, 的第三种内存模型
    int spitString2(const char * buf1,char c,char **myp/*in*/,int *count)    //**pp二级指针做输入
    {
    
        char *p=NULL, *pTmp = NULL;
        int    tmpcount = 0;
    
        //1 p和ptmp初始化
        p = buf1;
        pTmp = buf1;
    
        do
        {
            //2 检索符合条件的位置 p后移  形成差值 挖字符串
            p = strchr(p, c);
            if (p != NULL)
            {
                if (p-pTmp > 0)
                {
                    strncpy(myp[tmpcount], pTmp,  p-pTmp);
                    myp[tmpcount][p-pTmp]='';
                    tmpcount ++;
                    //3重新 让p和ptmp达到下一次检索的条件
                    pTmp = p = p + 1;
                }
            }
            else
            {
                break;
            }
        } while (*p!='');
    
        *count = tmpcount;
        return 0;
    
    }
    
    void main()
    {
        int ret=0,i;
        char *p1="abcdef,aaa,eeeee,ffffff,a3a3a3,";
        char tmp=',';
        char **p=NULL;
        int nCount;
    
        //可单独写个函数
        //char buf[10][30]
        p=(char **)malloc(10*sizeof(char *)); //char *array[10]
        if(p==NULL)
        {
            return;
        }
    
        for(i=0;i<10;i++)
        {
            p[i]=(char *)malloc(30 *sizeof(char));
            return ret;
        }
    
    
        ret=spitString2(p1,tmp,p,&nCount);
    
        if(ret !=0)
        {
            printf("fun spiltString() err:%d 
    ", ret);
        }
    
        for(i=0;i<nCount;i++)
        {
            printf("%s 
    ",p[i]);
        }
    
        for(i=0;i<10;i++)
        {
            free(p[i]);
        }
        free(p);
    
        printf("%d 
    ",nCount);
        printf("hello...
    ");
        system("pause");
    
    }
    Stay hungry,Stay foolish
  • 相关阅读:
    软件RAID 0
    逻辑卷管理lvm
    磁盘配额quota
    合并 CentOS 6.8 的两个ISO镜像
    挂载mount
    非交互式添加分区
    磁盘分区-gdisk用法
    C博客作业01--分支、顺序结构
    C语言--第0次作业
    浅议正则表达式
  • 原文地址:https://www.cnblogs.com/zhesun/p/4996228.html
Copyright © 2011-2022 走看看