| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 286 人关注过本帖
标题:有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
只看楼主 加入收藏
落雨的季节
Rank: 1
等 级:新手上路
帖 子:10
专家分:2
注 册:2012-12-12
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:5 
有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
我想编一个函数子串查找函数,作用是查找一个字符(子串)在另一个字符串中第一次出现的位置。(书上就是这样写的,但是在编译时输出始终有问题,总是输出-1)
#include<iostream>
#include<cstring>
using namespace std;
int find_substr(char str[],char sub_str[])  
{
  int len=strlen(str),
  sub_len=strlen(sub_str);
 for(int i=0;i<=len-sub_len;i++)
 {
  int j=0;
  while(j<sub_len&&sub_len==str[i+j])
   j++;
  if(j==sub_len)
   return i;
 }
 return -1;
}
int main()
{
 char a[10]="abcdefgh";
 char sub_a[]="bc";
 
 cout<<find_substr(a,sub_a)<<endl;
 return 0;
}

此时不是应该输出2吗?但实际输出是:-1
出现了什么问题呀?
搜索更多相关主题的帖子: namespace include return 字符串 
2013-03-05 19:01
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:5 
我砸 没看到你 哪里进行了子串的比较呢  思维不对啊

DO IT YOURSELF !
2013-03-05 20:05
落雨的季节
Rank: 1
等 级:新手上路
帖 子:10
专家分:2
注 册:2012-12-12
收藏
得分:0 
回复 2楼 wp231957
不用进行比较呀,就比如在abcdefghjjkllll中找出是否含有bcd子串一样呀~
2013-03-05 23:41
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:5 
要细心,到 第11行找找


[fly]存在即是合理[/fly]
2013-03-05 23:58
qunxingw
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:24
帖 子:1676
专家分:7295
注 册:2011-6-30
收藏
得分:5 
应该有信息提示查错吧

[ 本帖最后由 qunxingw 于 2013-3-6 09:12 编辑 ]

www.qunxingw.wang
2013-03-06 09:06
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:5 
while(j<sub_len&&sub_len==str[i+j])  -> while(j<sub_len&&sub_str[j]==str[i+j])

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-03-06 12:09
快速回复:有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
数据加载中...
 
   



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

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