| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 286 人关注过本帖
标题:有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
取消只看楼主 加入收藏
落雨的季节
Rank: 1
等 级:新手上路
帖 子:10
专家分:2
注 册:2012-12-12
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:1 
有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
我想编一个函数子串查找函数,作用是查找一个字符(子串)在另一个字符串中第一次出现的位置。(书上就是这样写的,但是在编译时输出始终有问题,总是输出-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
落雨的季节
Rank: 1
等 级:新手上路
帖 子:10
专家分:2
注 册:2012-12-12
收藏
得分:0 
回复 2楼 wp231957
不用进行比较呀,就比如在abcdefghjjkllll中找出是否含有bcd子串一样呀~
2013-03-05 23:41
快速回复:有关子串查找函数的编程,不知道问题出在哪儿~求大神指教~
数据加载中...
 
   



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

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