标题:查找子字符串出现的次数,有个bug
取消只看楼主
Spygg
Rank: 5Rank: 5
等 级:职业侠客
帖 子:135
专家分:394
注 册:2007-5-20
结帖率:100%
已结贴  问题点数:20 回复次数:1 
查找子字符串出现的次数,有个bug
/*程序功能找出一 字符串中包含某字字符串的次数
如:abcabcabcffabc
那么abc在母字符串中的次数就是4  
程序有点bug就是测试数据为ddddddfabcabcdd时,dd在母字符串中次数应该是4结果却为6
请教高手解答*/
#include<stdio.h>
#include<string.h>
#define MAX 100
int main(void)
{   
    char *sourse,*dst;
    char a[MAX],b[MAX];
    int dstlen=0,flag=0,time=0,tmp;
    sourse=a;
    dst=b;
    printf("Input the sourse string\n");
    gets(sourse);   
    printf("Input the dst string\n");  
    gets(dst);
    dstlen=strlen(dst);
    dst=b;
    if(dstlen==1)
    {
        while(*sourse!='\0')
        {
            if(*sourse==b[0])
                time++;
            sourse++;
        }
        printf("In it %d times",time);
        return 0;
    }
    tmp=dstlen;
    while(*sourse!='\0')  
    {     
        flag=0;
        if(*sourse==*dst)/*得到第一个相等的字符*/   
        {     
            dst++;   
            flag=1;
        }     
        if(*dst=='\0') /*如果字串结束则进行下一次测试*/
        {
            time++;
            dst=b;
            continue;  
        }
        sourse++;  
        if(flag) /*如果第一个字符相等则判断字串的第二个字符跟母串接下来的字符是否相等*/
            if(*dst!=*sourse)   
            {      
                flag=0;
                dst=b;
            }  
    }   
    printf("In it %d times\n",time);
    return 0;
}
搜索更多相关主题的帖子: bug 字符 
2010-07-05 21:21
Spygg
Rank: 5Rank: 5
等 级:职业侠客
帖 子:135
专家分:394
注 册:2007-5-20
得分:0 
/*输入abcabcabcff   ,然后查找abc出现的次数应该为三次*/
/*第一种算法感觉好麻烦,但是是我自己想出来的*/
#include<stdio.h>
#define MAX 100
int main(void)
{   
    char *sourse,*dst;
    char a[MAX],b[MAX];
    int dstlen=0,flag=0,time=0;
     sourse=a;
     dst=b;
     printf("Input the sourse string\n");
     gets(sourse);   
     printf("Input the dst string\n");  
       gets(dst);   
    while(*sourse!='\0')  
     {     
         flag=0;
           if(*sourse==*dst)/*得到第一个相等的字符*/   
         {     
               dst++;   
               flag=1;
           }     
          if(*dst=='\0') /*如果字串结束则进行下一次对比*/
         {
             time++;
             dst=b;
         }
           sourse++;  
          if(flag) /*如果第一个字符相等则判断字串的第二个字符跟母串接下来的字符是否相等*/
              if(*dst!=*sourse)   
             {         
                   dst=b;
                continue;   
             }  
       }   
         printf("In it %d tiems\n",time);  
}


/*第二种算法,借鉴了K&R书中的算法,比较经典各位看客也可以对比下哈*/
#include<stdio.h>
#include<string.h>
#define MAX 100
int main(void)
{
    int i,j,k=0,time=0,l=0;
    char *sourse,*dst,a[MAX],b[MAX];
     sourse=a;
     dst=b;
     printf("Input sourse string\n");
     gets(sourse);
     printf("Input dst string\n");
     gets(dst);
     l=strlen(dst);
     printf("%d\n",l);
    for(i=0;*(sourse+i)!='\0';i++)
     {
        for(j=i,k=0;*(dst+k)!='\0'&&*(sourse+j)==*(dst+k);j++,k++)
             ;
            if(*(dst+k)=='\0')
             {
                 time++;
                 i=i+l-1;/*这句很重要不然就会出现dddddff查找dd次数为4的问题*/
             }
   
     }
         printf("dst sting In sourse string %d times\n",time);
}
2010-07-15 00:04



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-312215-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.057722 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved