
c++题 寻找子字符串深圳
3个回答
展开全部
#include<iostream.h>
#include<string.h>
int find(char s[],char t[])
{int i,j;
for(i=0;;i++)//s[i]?
for(j=0;;j++)//t[j]?
{if ((s[i]!=t[j])&&t[j])break;
if (!t[j]) return i-j+1;
i++;}
return -1;}
void main(void)
{char s[30],t[30];
cout<<"输入第一个字符串:"<<endl;
cin.getline(s,30);
cout<<"输入第二个字符串:"<<endl;
cin.getline(t,30);
if (find(s,t)==-1) cout<<"未找到!"<<endl;
else cout<<"在第"<<find(s,t)<<"个"<<endl;
}
c++提供了stirng类,就用string吧!很方便的,没有仔细的去检查你的错误,应该是for循环时没有求出数组的长度。
#include<iostream>
#include<string>
using namespace std;
int find(string s,string t)
{
int i,j;
for(i=0;i<s.length();i++)
for(j=0;t.length();j++)
{
if ((s[i]!=t[j])&&t[j])break;
if (!t[j]) return i-j+1;
i++;
}
return -1;
}
void main(void)
{
string s,t;
cout<<"输入第一个字符串:"<<endl;
cin>>s;
cout<<"输入第二个字符串:"<<endl;
cin>>t;
if (find(s,t)==-1) cout<<"未找到!"<<endl;
else cout<<"在第"<<find(s,t)<<"个"<<endl;
}
#include<string.h>
int find(char s[],char t[])
{int i,j;
for(i=0;;i++)//s[i]?
for(j=0;;j++)//t[j]?
{if ((s[i]!=t[j])&&t[j])break;
if (!t[j]) return i-j+1;
i++;}
return -1;}
void main(void)
{char s[30],t[30];
cout<<"输入第一个字符串:"<<endl;
cin.getline(s,30);
cout<<"输入第二个字符串:"<<endl;
cin.getline(t,30);
if (find(s,t)==-1) cout<<"未找到!"<<endl;
else cout<<"在第"<<find(s,t)<<"个"<<endl;
}
c++提供了stirng类,就用string吧!很方便的,没有仔细的去检查你的错误,应该是for循环时没有求出数组的长度。
#include<iostream>
#include<string>
using namespace std;
int find(string s,string t)
{
int i,j;
for(i=0;i<s.length();i++)
for(j=0;t.length();j++)
{
if ((s[i]!=t[j])&&t[j])break;
if (!t[j]) return i-j+1;
i++;
}
return -1;
}
void main(void)
{
string s,t;
cout<<"输入第一个字符串:"<<endl;
cin>>s;
cout<<"输入第二个字符串:"<<endl;
cin>>t;
if (find(s,t)==-1) cout<<"未找到!"<<endl;
else cout<<"在第"<<find(s,t)<<"个"<<endl;
}
展开全部
使用string类的find。如:
#include <iostream>
#include <string>
using namespace std;
void main()
{
string s1="abcdefg",s2="def";
cout<<s1.find(s2)<<endl;
}
结果:3
#include <iostream>
#include <string>
using namespace std;
void main()
{
string s1="abcdefg",s2="def";
cout<<s1.find(s2)<<endl;
}
结果:3
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果是C模式的字符数组,则可以先包含头文件<cstring>,然后用库函数strstr来字串定位,不过返回值类型是指针
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询