首页 > 其他 > 详细

剔除三个(包括三个以上)的子串

时间:2016-09-10 00:05:47      阅读:222      评论:0      收藏:0      [点我收藏+]
#include <iostream>

#include <stdio.h>

using namespace std;

char *str(char *p)
{
    char *p1;
    p1 = (char*)malloc(strlen(p)+1);
    memset(p1,\0,strlen(p)+1);    
    int count = 0;
     int i,j;
    int x,y;
     int w;
    bool b = 1;

    while(b)
    {
        b = 0;
        w = (signed)strlen(p);
        x=0;
        y=strlen(p);
        for(i = 0; i < w-2; i++)
        {
            if((p[i] == p[i+1]) && (p[i+1] == p[i+2])) 
            {
                x = i;
                y = i+2;
                b = 1;
                for(j = i+3; j < strlen(p); j++ ) 
                {
                if(p[x] == p[j])
                    y = j;
                else break;
                } 
            }  
            if(b ==1) break;
        }
        if(b == 1)
        {
        for(i = 0; i < x; i++)
        {
              p1[i] = p[i];
        }
        for(j = y+1; j < strlen(p); j++)
        {
              p1[i] = p[j];
              i++;
        }
        memset(p,\0,strlen(p));
        for(i = 0; i < strlen(p1); i++)
        {
              p[i] = p1[i];
        }
        memset(p1,\0,strlen(p));
        }
        
            
    }

    return p;
}

int main()
{
    char p[] = "daaacbbbacbbbccaa";
    cout<<str(p)<<endl;
}

 

剔除三个(包括三个以上)的子串

原文:http://www.cnblogs.com/dongzhuangdian/p/5858238.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!