EduCoder-程序设计技术R-字符数组-第5关:字符串统计

任务描述

题目描述:输入一段字符(由空格、字母和数字几种组成,保证开头不为空格),里面有若干个字符串,求这些字符串的长度和,并输出最长字符串内容,如果有多个输出最先出现的那个字符串。以stop作为最后输入的字符串。

相关知识

编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。
输入
输入一段文字
输出
输入一段字符,以stop作为最后输入的字符串。

测试说明

样例输入:
My name is Amy
My name is Jane
stop
样例输出:
11 name
12 name
提示:
字符串长度不超过100。

注意:使用gets()函数会引起警告,但正确使用不影响测评结果。
推荐使用:fgets()函数。

开始你的任务吧,祝你成功!

代码示例

/* 第5关:字符串统计 */

#include<stdio.h>
#include <string.h>

#define N 1024
char s[N + 1], t[N + 1];

int main(void)
{
    /*********Begin*********/
    fgets(s, N, stdin);
    for(;;) {
        if(strncmp(s, "stop", 4) == 0 && s[4] == '\n')
            break;

        int sum = 0, maxlen = 0;
        char *p;
        p = strtok(s, " \t\n");
        while(p) {
            int len = strlen(p);
            if(len > maxlen) {
                maxlen = len;
                strcpy(t, p);
            }
            sum += len;

            p = strtok(NULL, " \t\n");
        }

        printf("%d %s\n", sum, t);

        fgets(s, N, stdin);
    }
    /*********End**********/
    return 0;
}

  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 题目描述输入一段字符(由空格字母数字几种组成保证开头不为空格),里面有若干个字符串,求这些字符串的长度和,并输出最长字符串内容,如果有多个输出最先出现的那个字符串。以 stop 作为最后输入字符串。 答案:根据题目描述输入一段字符串里面有几个子字符串,先找到所有子字符串的长度和,再用循环逐个查找字符串,输出最长字符串内容,并且当找到 stop 时,停止循环,输出最终结果。 ### 回答2: 题目描述给定一个字符串,其中包含若干个子串,每个子串之间用空格隔开。要求计算出每个子串的长度,并将所有子串的长度相加,同时输出其中长度最长的子串及其内容(如果有多个长度相同的子串,输出最先出现的那个子串)。 首先,我们需要读入输入字符串,并用split()函数将其按照空格分割成一个子串列表。接下来,我们可以使用一个循环遍历每个子串,分别计算其长度并将长度累加到总长度中。同时,我们需要记录当前最长的子串并将其与每个子串比较,更新最长子串的值。 最后,当我们读入到一个特定的标记字符串“stop”时,我们可以统计出最后的结果并输出最长子串的内容。具体代码如下: ``` # 定义一个变量来记录总长度和最长子串的长度 total_length = 0 max_length = 0 max_string = '' # 循环读入每个子串 while True: input_string = input('请输入字符串:') if input_string == 'stop': break # 当输入为"stop"时退出循环 else: # 按照空格分隔字符串,并对每个子串进行处理 string_list = input_string.split() for string in string_list: curr_length = len(string) total_length += curr_length # 累计总长度 if curr_length > max_length: # 更新最长子串信息 max_length = curr_length max_string = string # 输出结果 print('总长度为:', total_length) print('最长子串为:', max_string) ``` 这段代码的核心部分是用一个for循环遍历每个子串,并计算其长度,同时用一个if语句更新最大长度和最长子串的信息。最后,在遍历所有子串后,我们可以输出计算出的总长度和最长子串的内容。 ### 回答3: 这道题目要求我们输入一段字符,其中包含多个字符串,我们需要求出这些字符串的长度和。同时,我们还需要找到这些字符串中最长的那一个,并输出它的具体内容。如果有多个最长的字符串,则我们需要输出最先出现的那一个。 我们可以通过读入字符的方式来解决这个问题。具体来说,我们可以使用循环来读入字符,每次读入一个字符后,我们都先将它存储到一个缓存区里。当我们读到一个空格或者换行符时,就说明一个字符串已经结束了。此时,我们就可以把缓存区里的字符拼接起来,得到一个完整的字符串。然后,我们可以记录下当前字符串的长度,并累加到之前所有字符串的长度和中。 当我们读到一个"stop"字符串时,就说明输入结束了。此时,我们就可以根据之前记录的最长字符串长度,找到最长的那一个字符串并输出它的具体内容。 下面是一个可能的代码实现: ```python s = input() # 读入一行字符 total_length = 0 # 字符串长度和 max_length = 0 # 最长字符串长度 max_string = '' # 最长字符串内容 while s != 'stop': buffer = '' # 缓存区 for ch in s: if ch != ' ' and ch != '\n': # 如果当前字符不是空格或换行符,就把它存放到缓存区里 buffer += ch else: # 否则,就表示一个字符串已经结束了,我们需要把缓存区里的字符拼接起来并统计长度 length = len(buffer) total_length += length if length > max_length: # 如果当前字符串长度比最长字符串长度长,就更新最长字符串的相信息 max_length = length max_string = buffer buffer = '' s = input() print("所有字符串的长度和为:", total_length) print("最长的字符串是:", max_string) ``` 需要注意的是,这个代码实现并没有考虑特殊情况,比如输入中有多个连续的空格输入中只有一个字符串等等。实际使用时,我们需要对这些情况进行特殊处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值