[PTA]实验8-2-2 找最长的字符串

Spring-_-Bear 的 CSDN 博客导航

本题要求编写程序,针对输入的 N 个字符串,输出其中最长的字符串。

输入格式:

输入第一行给出正整数 N;随后 N 行,每行给出一个长度小于 80 的非空字符串,其中不会出现换行符,空格,制表符。

输出格式:

在一行中用以下格式输出最长的字符串:

The longest is: 最长的字符串
如果字符串的长度相同,则输出先输入的字符串。

输入样例:

5
li
wang
zhang
jin
xiang

输出样例:

The longest is: zhang

来源:

来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/13/exam/problems/545

提交:

在这里插入图片描述

题解:

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

int main(void) {
    int N;
    scanf("%d", &N);

    char s[80];
    scanf("%s", s);
    char maxS[80];
    // 假设输入的第一个字符串最长
    strcpy(maxS, s);

    // 继续输入剩下的 N-1 个字符串,如果新输入的字符串长于 maxS,则更新 maxS
    for (int i = 1; i <= N - 1; i++) {
        scanf("%s", s);
        if (strlen(s) > strlen(maxS)) {
            strcpy(maxS, s);
        }
    }

    printf("The longest is: %s", maxS);

    return 0;
}
### 关于PTA平台C语言字符统计实验的解题思路 在解决PTA平台上涉及字符统计的实验时,通常需要关注以下几个方面: 1. **输入处理**:读取并解析输入数据。可以利用标准库函数`scanf()`或`fgets()`来获取用户输入[^2]。 2. **字符分类**:区分字母、数字和其他字符(如标点符号)。可以通过条件判断语句或者调用`ctype.h`头文件中的函数完成这一操作[^3]。 3. **计数逻辑**:设计变量用于存储不同类别字符的数量,并随着遍历字符串逐步更新这些数值[^4]。 下面提供一段基于上述原则编写的示例代码,展示如何实现基本的字符统计功能: ```c #include <stdio.h> #include <ctype.h> int main() { char str[101]; // 定义一个足够大的数组保存输入字符串 int letters = 0, digits = 0, others = 0; printf("请输入一行文字:\n"); fgets(str, sizeof(str), stdin); // 使用fgets安全地接收整行输入 for (int i = 0; str[i] != '\0'; ++i) { // 遍历整个字符串直到遇到结束符'\0' if (isalpha(str[i])) { // 判断当前字符是否为英文字母 letters++; } else if (isdigit(str[i])) { // 判断当前字符是否为阿拉伯数字 digits++; } else { // 剩余情况视为其他类字符 others++; } } printf("Letters=%d\nDigits=%d\nOthers=%d\n", letters, digits, others); return 0; } ``` 此程序首先定义了一个大小适配的任务需求的字符数组用来装载用户的键盘录入内容;接着初始化三个整型变量分别记录各类目标对象数目;最后通过循环逐一审查每一个单元格里的成分属性从而累加相应类型的总计次数[^5]。 ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春天熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值