7-10 单词长度 (15分)(超详细讲解)

你的程序要读入一行文本,其中以空格分隔为若干个单词,以.结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it’s算一个单词,长度为4。注意,行中可能出现连续的空格;最后的’.'不计算在内。

输入格式:
输入在一行中给出一行文本,以’.'结束
提示:用scanf("%c",…);来读入一个字符,直到读到.为止。

输出格式:
在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。

输入样例:
It’s great to see you here.
输出样例:
4 5 2 3 3 4

分析:
所给样例不具备代表性。因此我们要先找一个具有一定代表性的样例,然后对此分析。因此我们首先修改样例如下:
(多个空格)It’s(多个空格)great to see you here(多个空格).
输出结果:
4 5 2 3 3 4(后面没有空格)
我们主要虑两个问题:(1)一个单词开始的标志。(2)一个单词的结束标志。
本人认为一个单词的开始也是上一个单词的结束。也就是说我们在统计某个单词的字符数时,也把空格暂时计入字符数中,当出现下一次输入不再是空格时,立即统计这个单词数(公式为:总字符数-空格数-1)然后开始下一次字符计数。

此处有几项主要注意点:(1)空语句时程序什么也不输出。(2)如果总字符数-空格数-1为零时,什么也不输出(解决开头多个空格问题)。(3)遇到’.’程序停止然后输出最后一次结果且后面没有空格。

代码展示如下

#include<stdio.h>

int main(void)
{
    int letter=0;
    int blank=0;
    char input=0;

    for(;;)
    {
        input=getchar();
        if(input==32)
            ++blank;
        ++letter;
        if(input==46) //解决遇到'.'问题
            {
                if(letter-blank==1) //此处解决空语句问题
                return 0;
                printf("%d",letter-blank-1);
                return 0;
            }
        if(input!=32&&blank>0) //当下一次读入不再是空格时,blank大于零保证上一个单词输入完成
        {
            if(letter-blank>1) //判断某个单词字符数大于零
                printf("%d ",letter-blank-1);
            blank=0;
            letter=1;
        }
    }
    return 0;
}

  • 17
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
re.findall(pattern, string, flags) 是一个 Python 正则表达式模块(re)的方法,用于从字符串中找到所有与给定模式匹配的非重叠部,并以列表的形式返回它们。它的语法如下: ```python re.findall(pattern, string, flags=0) ``` 其中,参数 pattern 是正则表达式模式,参数 string 是要匹配的字符串,参数 flags 是可选的标志参数,用于控制正则表达式的匹配方式。 下面是几个关于 re.findall() 方法的示例: **示例 1:基本用法** ```python import re string = "The quick brown fox jumps over the lazy dog." pattern = "the" matches = re.findall(pattern, string, flags=re.IGNORECASE) print(matches) # Output: ['The', 'the'] ``` 在此示例中,我们定义了一个字符串和一个模式,用于在字符串中查找所有匹配模式的单词。我们使用 re.IGNORECASE 标志来忽略模式中的大小写,然后使用 re.findall() 方法从字符串中找到所有匹配的单词,并返回它们的列表。 **示例 2:使用捕获组** ```python import re string = "John has 6 apples, and Mary has 3 oranges." pattern = "(\w+) has (\d+)" matches = re.findall(pattern, string) print(matches) # Output: [('John', '6'), ('Mary', '3')] ``` 在此示例中,我们定义了一个字符串和一个模式,用于在字符串中查找匹配模式的人名和他们拥有的水果数量。我们使用括号来创建一个捕获组,以捕获人名和数字,然后使用 re.findall() 方法从字符串中找到所有匹配的结果,并返回它们的元组列表。 **示例 3:使用正则表达式标志** ```python import re string = "The quick brown fox jumps over the lazy dog." pattern = r"\b\w{3}\b" matches = re.findall(pattern, string, flags=re.IGNORECASE) print(matches) # Output: ['The', 'fox', 'the', 'dog'] ``` 在此示例中,我们定义了一个字符串和一个模式,用于在字符串中查找所有长度为 3 的单词。我们使用了 r 前缀来创建一个原始字符串,以便我们可以使用正则表达式中的特殊字符来匹配单词边界。我们还使用 re.IGNORECASE 标志来忽略大小写,并使用 re.findall() 方法从字符串中找到所有匹配的单词,并返回它们的列表。 综上所述,re.findall(pattern, string, flags) 是一个非常有用的方法,可以用于查找和提取字符串中与给定模式匹配的所有子字符串。它可以使用正则表达式中的各种特殊字符和标志来实现高级匹配功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值