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

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


  • 9
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值