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


单词替换在程序设计一个常见的任务,特别是在文本处理、自然语言处理等领域有着广泛的应用。在C语言实现单词替换通常需要对字符串操作有较好的掌握,主要包括字符串比较、字符串复制等基本功能。 ### C语言实现步骤: #### 1. 确定目标字符串 首先,确定你需要替换的原始字符串(例如句子 "Hello World" 的 "World")。这可以通过读取文件、用户输入等方式获得。 #### 2. 检查并替换字符串 接下来,你需要遍历整个字符串,并逐个检查字符直到找到目标字符串。一旦找到目标字符串,就需要将它替换为你想要的新字符串。这个过程涉及到一系列字符串操作,包括查找和复制等。 ```c #include <stdio.h> #include <string.h> void replace_word(char *str, const char *old_word, const char *new_word) { int str_len = strlen(str); int old_word_len = strlen(old_word); int new_word_len = strlen(new_word); // 查找单词的位置 size_t pos = 0; while ((pos = strstr(str, old_word)) != NULL) { // 计算新单词应放置的位置,加上老单词长度是为了覆盖掉旧单词,然后加新单词长度 int new_pos = pos - 1 + old_word_len; // 使用内存复制函数 memcpy 替换指定位置后的字符串部分 memmove(&str[new_pos], &str[pos], (str_len - pos + new_word_len + 1)); // 将新的单词插入到正确位置 strncpy(str + pos, new_word, new_word_len); str[pos + new_word_len] = '\0'; // 保证字符串结束符的存在 // 更新搜索起始点,跳过已经修改的部分 pos -= old_word_len; } } int main() { char text[] = "Hello World"; const char *target[] = {"World"}; const char *replacement[] = {"Universe"}; for (size_t i = 0; i < sizeof(target)/sizeof(target); ++i) { replace_word(text, target[i], replacement[i]); } printf("Replaced string is: %s\n", text); return 0; } ``` ### 相关问题: 1. **如何高效地进行大规模文本的单词替换?** - 对于大量数据的处理,可以考虑使用更高效的算法或库,如利用正则表达式(在支持正则表达式的C环境),或者优化内存管理和字符串操作以减少性能损耗。 2. **在C语言如何检测是否存在特定单词并在字符串进行替换?** - 可以使用`strstr()`函数来寻找字符串存在的特定单词,结合上述示例的`replace_word()`函数进行替换。 3. **如何处理包含特殊字符和空格的字符串,使其单词替换更为准确?** - 需要在代码适当处理字符串边界条件以及特殊字符的情况,比如在分割字符串和进行替换操作前先去除多余的空格或特殊字符,确保每个单词都能被正确识别和替换
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值