用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;
}