| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1910 人关注过本帖
标题:查找子字符串出现的次数,有个bug
只看楼主 加入收藏
Spygg
Rank: 5Rank: 5
等 级:职业侠客
帖 子:135
专家分:394
注 册:2007-5-20
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
查找子字符串出现的次数,有个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
唐门黄老邪
Rank: 2
等 级:论坛游民
帖 子:5
专家分:14
注 册:2010-3-16
收藏
得分:14 
本程序的代码没有错误,算法也没有错误。答案是6美错。关键在于ddddddfabcabcdd的特殊性。程序是这样计算的。最前面两个dd为第一次出现,然后是第二第三个dd为第二次出现,接着是第三第四个dd为第三次出现,以此类推,正好出现6次dd。
2010-07-06 02:13
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
快速回复:查找子字符串出现的次数,有个bug
数据加载中...
 
   



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

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