#include <iostream>
using namespace std;
//查找子字符串 并返回第一个字母
char* find_char( char* source, char* chars) //这里主要因为赋值 所以没有使用const
{
char* p = source;
char* q = chars;
while(*p != NULL)
{
if(*p != *q) //将if语句提取到外面 效率更高
{
p++;
source++;
}
else
{
while(*q != NULL)
{
if(*p == *q)
{
p++;
q++;
}
}
if(*q == NULL)
break;
else
{
q = chars;
p = ++source;
}
}
}
if(*source == NULL)
return NULL;
return source;
}
int del_substr(char *str, char* substr) //在里面找到就返回1 不在返回0
{
char *p = str;
char *q = substr;
int len = strlen(substr);
char *index = find_char(p, q);
if(*index == NULL)
{
cout<<"the substr isn't in the str"<<endl;
return 0;
}
else
{
while(*p != NULL && p != index)
p++; //获取位置
char *q = p+len;
while(*q != NULL)
{
p = q;
q++;
p++;
}
}
return 1;
}
void reverse_string(char* str) //进行字符串的反转
{
int len = strlen(str);
char *p = str;
char *q = str+len-1;
char ch;
while(p < q)
{
ch = *p;
*p++ = *q;
*q-- = ch;
}
}
int main()
{
//其实在这里还是需要判断下的 总不能对NULL取指针吧。。。。
char *p = "SmithJackji";
char *q = "Jack";
return 0;
}
using namespace std;
//查找子字符串 并返回第一个字母
char* find_char( char* source, char* chars) //这里主要因为赋值 所以没有使用const
{
char* p = source;
char* q = chars;
while(*p != NULL)
{
if(*p != *q) //将if语句提取到外面 效率更高
{
p++;
source++;
}
else
{
while(*q != NULL)
{
if(*p == *q)
{
p++;
q++;
}
}
if(*q == NULL)
break;
else
{
q = chars;
p = ++source;
}
}
}
if(*source == NULL)
return NULL;
return source;
}
int del_substr(char *str, char* substr) //在里面找到就返回1 不在返回0
{
char *p = str;
char *q = substr;
int len = strlen(substr);
char *index = find_char(p, q);
if(*index == NULL)
{
cout<<"the substr isn't in the str"<<endl;
return 0;
}
else
{
while(*p != NULL && p != index)
p++; //获取位置
char *q = p+len;
while(*q != NULL)
{
p = q;
q++;
p++;
}
}
return 1;
}
void reverse_string(char* str) //进行字符串的反转
{
int len = strlen(str);
char *p = str;
char *q = str+len-1;
char ch;
while(p < q)
{
ch = *p;
*p++ = *q;
*q-- = ch;
}
}
int main()
{
//其实在这里还是需要判断下的 总不能对NULL取指针吧。。。。
char *p = "SmithJackji";
char *q = "Jack";
cout<<del_substr(p,q)<<endl;
char p[]= "Smith";
reverse_string(p);return 0;
}