子字符串

写一个函数int find(char s[],char t[]),该函数在字符串s中查找字符串t,如果找到,则返回字符串t在字符串s中的位置(整数值);否则返回-1.注意:用数组方式及两重循环来实现该函数.

#include<iostream>
using namespace std;
int find(char s[],char t[])
{
    int len1=strlen(s),len2=strlen(t),i=0,j=0,k;
    if(len1<len2)return -1;
    while(i<=len1-len2)
    {
        k=i+1;
        if(s[i]-t[j])i++;
        else
{
    while(1)
    {
if(s[i++]-t[j++]){j=0;i=k;break;}
if(j==len2)return i-len2;
    }
         }
    }
    return -1;
}
int main()
{
    char s[]="Hello C++  Jav Hello Java";
    char t[]="Java";
    cout<<find(s,t)<<endl;
    system("PAUSE");
    return 0;
}

============================================================================

#include<iostream>
using namespace std;
int find(char *str1,char *str2)
{
    char *p=str1,*p1=str2,*q;
    while(*p)
    {
        if(*p==*p1)
        {
           q=p;
           do{
       if(*p==*p1)p++,p1++;
               else {p1=str2;break;}
         }while(*p1&&*p);
         if(!*p1)return q-str1+1;
         }
 else p++;
     } 
     return 0;
}  
int main()
{
    char str1[]="abcc",str2[]="abc";
    cout<<find(str1,str2)<<endl;
    system("PAUSE");
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值