您的位置:首页 > 编程语言 > C语言/C++

C语言实现在英语句子查找和替换一个单词。

2015-09-09 09:55 906 查看
用C语言实现从字符串中读取存在单词的位置,并替换成别的单词,可用于英语句子中的单词替换。

注意:

1、该程序被替换的是单个单词,而不是单词里的字符,如替换"like"里的'i'为'u'。

效果图如下:



2、被替换的不能是多个单词的组合,如替换"like
you"为"hate you"。

效果图如下:



3、被替换的单词只能是单个单词,如替换"like
you"里的"you"为"me"。

效果图如下:



4、替换的单词可以为多个,如替换"like
you"里的"you"为"you and me"。

效果图如下:



具体代码如下:(可能存在不足之处,希望能给予指出,谢谢!)

#include <stdio.h>
#include <stdlib.h>
#include<string.h>

int searchWord(char S[],char W[]);
char* replaceWord(char S[], char W[], int pos, char R[]);

int main(){
char S[100]="like you";
char temp0[20];
char temp1[20];
char *result;

int i;
printf("原文字为:%s\n请输入要替换的单词:",S);
gets(temp0);
i=searchWord(S,temp0);
if(i==-1){
printf("句子里不存在该单词!");
}
else{
printf("请输入要替换的单词:");
gets(temp1);
result = replaceWord(S,temp0,i,temp1);
printf("%s",result);
}
return 0;
}

//查询单词在句子的开端S代表Sentence(句子),W代表Word(单词)
int searchWord(char S[],char W[]){
int i,j;				//循环变量
int n;					//句子长度+1('\0')
int k;					//单词长度

n=strlen(S)+1;			//获取句子长度+1('\0')
k=strlen(W);			//获取单词长度

for(i=0;i<n-k;i++){			//循环到n-k,因为n-k后面,找不到含有k个字符的单词了。
for(j=0;j<k;j++){				//循环单词每个字母
if(S[i+j]!=W[j]||W[j]==' '){		//当S[i+j]不与W[j]相等,或者单词里出现空格时跳出
break;
}
}
if(j==k&&(S[i+j]==' '||S[i+j]=='\0')){
/*j==k,表示句子里存在与单词完全匹配的字母(可能还不是单词)。如String与tri此时匹配能成功。
而S[i+j]等于' '或者'\0',表示句子后面分割或者结束。但匹配的段落前面不一定分割。
如String与ing匹配能成功,但String与tri匹配就不能成功了。*/
if(i==0||(i>0&&S[i-1]==' ')){		//此处判断是否有前分割,只有句首和存在前分割的段落才是单词
return i;
}
}
}
return -1;
}

char* replaceWord(char S[], char W[], int pos, char R[]){
int sizeS = strlen(S)+1;
int sizeW = strlen(W);
int sizeR = strlen(R);
int size = sizeS - sizeW + sizeR;
int i, j;
char* result = (char*)malloc(sizeof(char)*size);			//程序未释放内存,你们可按需要改进

for(i=0;i<pos;i++){
result[i] = S[i];
}
for(i=pos;i<pos+sizeR;i++){
result[i] = R[i-pos];
}
for(pos+sizeR;i<size;i++){
result[i]=S[i+sizeW-sizeR];
}
return result;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: