单词长度c语言实现

单词长度(这题有很多版本,看看适不适合你。)

Description

编写程序,输入一行字符,统计每个单词的长度。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。

 

Input

输入给出一行字符。

 

Output

在一行中输出每个单词的长度。各单词长度之间用1个空格隔开。

如果单词数为0,则输出0。

 

输入样例 1 

How are you?

输出样例 1

3 3 4

 

以下是编程部分

21f4fce267b24ecfbe36c12859206efb.png

 

说明:

这个题目要考虑各种可能的输入方式,我尽量说清楚。

1.先说整体框架,用到了scanf函数的缓存区存储数据的特点并使用while循环连续读入字符数据并对其进行处理。

2.count用于计数单词长度。notFirst用于控制输出时结果之间的空格。(这题目非要卡空格,有点莫名其妙。)

3.第四行定义temp=' ' 的作用是与第七行的if语句一起跳过连续的空格使其不进入计数(包括开头有空格形如"  hi!"这种输入)。

4.judge可以看到是与21-23行代码一起控制特殊结尾的输出的。judge对应的是在输入时连续输入一段空格时输出结果0。而21-23行用于形如"how are you?\n"这种句子"you?"这种末尾部分的计数和输出。(注:这句里的\n是系统行末自动加的,是隐藏的,这里我把它暴露出来,请自行与第六行相理解。)

5.第六行whlie里的条件如果看不懂请chatgpt一下吧   ❛˓◞˂̵✧   scanf函数是有int类型的返回值的。

6.第9-10行c==' '与count--使读取遇到空格时形成停留处并进行数据的处理和输出。(即代表一个单词结束了。)

 

 

感谢阅读_(´_`」 ∠)_

单词替换在程序设计中是一个常见的任务,特别是在文本处理、自然语言处理等领域中有着广泛的应用。在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. **如何处理包含特殊字符和空格的字符串,使其单词替换更为准确?** - 需要在代码中适当处理字符串边界条件以及特殊字符的情况,比如在分割字符串和进行替换操作前先去除多余的空格或特殊字符,确保每个单词都能被正确识别和替换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值