最长字符串(指针专题)

题目描述

输入多个字符串,输出最长字符串。要求定义并使用函数maxLenStr(), void maxLenStr(char ×str[], int n, int ×max) { 从字符串数组str中找出最长的一个字符串,并将其下标存入形参指针max所指内存。 }


输入描述

输入有多行,每行一个字符串,每个字符串长度不超过80,输入最多不超过100行,用***×作为结束输入的标志,该行输入不用处理。


输出描述

输出最长的一个字符串。


输入样例

L love C programming
ACM/ICPC
study hard
****


输出样例

L love C programming

 

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

void maxLenStr(char *str[], int n, int *max) {
    *max = 0;  // 初始最大长度为0

    for (int i = 1; i < n; i++) {
        if (strlen(str[i]) > strlen(str[*max])) {
            *max = i;  // 更新最大长度的字符串下标
        }
    }
}

int main() {
    const int MAX_LINES = 100;
    const int MAX_LENGTH = 80;

    char *str[MAX_LINES];
    char input[MAX_LENGTH + 1];  // +1 用于存储字符串结尾的 null 字符

    // 输入字符串
    int n = 0;
    while (1) {
        fgets(input, sizeof(input), stdin);
        input[strcspn(input, "\n")] = '\0';  // 移除换行符

        if (strcmp(input, "***") == 0) {
            break;  // 遇到结束标志则停止输入
        }

        str[n] = strdup(input);  // 使用strdup复制字符串
        n++;
    }

    // 调用函数找出最长的字符串
    int maxIndex;
    maxLenStr(str, n, &maxIndex);

    // 输出最长的字符串
    printf("%s\n", str[maxIndex]);

    // 释放动态分配的内存
    for (int i = 0; i < n; i++) {
        free(str[i]);
    }

    return 0;
}

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值