| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 610 人关注过本帖
标题:我想寻找子字符串的位置,可输出的总是Not Found
只看楼主 加入收藏
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
结帖率:88.89%
收藏
已结贴  问题点数:10 回复次数:10 
我想寻找子字符串的位置,可输出的总是Not Found
由键盘输入两个字符串(假设第一个字符串必包含第二个字符串,如第一个字符串为ABCDEF,第二个为CDE,则CDE包含在ABCDEF)

#include <stdio.h>
int main()
{
    int i,j;
    char a[80],b[80];
    gets(a);gets(b);
    for(i=0;a[i]!='\0';i++)
    {
        for(j=0;b[j]!='\0';j++)
        {
            if(a[i+j]!=b[i]) break;
            if(b[j]=='\0') break;
        }
    }
    if(a[i]!='\0') printf("%d",i+1);
    else printf("Not Found");
    return 0;
}
搜索更多相关主题的帖子: include return 字符串 键盘 
2015-11-07 16:10
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
用上次教你的分析法倒過來查找原因。

btw: 查找子串,沒你想象的那麽簡單。

授人以渔,不授人以鱼。
2015-11-07 20:17
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
收藏
得分:0 
回复 楼主 涧边幽草
请问如何倒过来
2015-11-07 21:05
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
绲愭灉鍑虹従浜唍ot found锛岄偅楹兼槸浠

授人以渔,不授人以鱼。
2015-11-07 21:48
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
收藏
得分:0 
回复 4楼 TonyDeng
试了好久,还是找不出来,请版主明示
2015-11-07 22:55
暴风晕
Rank: 12Rank: 12Rank: 12
来 自:冥界
等 级:火箭侠
威 望:6
帖 子:402
专家分:3107
注 册:2015-8-8
收藏
得分:3 
楼主可以把printf嵌进去,有一个输出一个位置,或者再弄个数组,位置存起来,然后输出数组
2015-11-07 23:46
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:3 
既然出現Not found,看看那if的條件是啥。

[此贴子已经被作者于2015-11-7 23:56编辑过]


授人以渔,不授人以鱼。
2015-11-07 23:54
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
收藏
得分:0 
回复 7楼 TonyDeng
我换了一种方法,我试了很多情况,都输入输出满足题意要求,可是当我复制到网上刷题系统并上交
,它给我的答复是错的,可我找不出错在哪了,请你帮我看一下。
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
int main()
{
    int i,m,n,t,k,count=0;
    char a[80],b[80];
    gets(a);gets(b);
    t=strlen(b);
    for(i=0;a[i]!='\0';i++)
    {
        if(a[i]==b[0])
        {
            if(a[t+i-1]==b[t-1])
            {
               k=i+1;
               for(m=i+1,n=1;m<t+i&&n<t;m++,n++)
               {
                   if(a[m]==b[n])
                   {
                       count++;
                   }
                   else break;
               }
            }
        }
        else continue;
        if(count==t-1) printf("%d",k);
    }
    return 0;
}
2015-11-09 10:51
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:4 
如果仅仅有一个匹配的  那么就好办一些
如果有n个匹配的 就麻烦一些

比如 aaaaaaaaaaaaaa  里面包含几个aaa

DO IT YOURSELF !
2015-11-09 11:07
涧边幽草
Rank: 2
等 级:论坛游民
帖 子:37
专家分:15
注 册:2015-11-4
收藏
得分:0 
回复 9楼 wp231957
谢谢,经修改,已通过了
2015-11-09 16:49
快速回复:我想寻找子字符串的位置,可输出的总是Not Found
数据加载中...
 
   



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

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