解题思路:利用两个数组来分别存放每个单词的大小和对应的句子中每个单词开始的元素下标

注意事项:每个单词的元素下标记得从0开始

参考代码:

int main()

{

    char str[2000] = { 0 };

    int a[200] = { 0 };//存放每个单词的大小

    int b[200] = { 0 };//存放每个单词开始位置的下标号

    int i = 0, k = 0, j = 0, m1 = 0, m2 = 0;

    int max = 1, min = 1;

    gets(str);

    //计算每个单词的大小和开始下标

    while (str[i])

    {

        j = 0;

        b[k] = i;

        while (str[i] != ' ' && str[i] != '\0')

        {

            i++;

            j++;

        }

        if (j != 0)

        {

            a[k] = j;

            k++;

        }

        i++;

    }


    //找出最长和最短单词的长度

    for (i = 0; i < k; i++)

    {

        max = (a[i] > max) ? (a[i]) : (max);

        min = (a[i] < min) ? (a[i]) : (min);

    }

    //找出第一个最长最短单词的元素下标

    for (i = 0; i < k; i++)

    {

        if (a[i] == max)

        {

            max = b[i];//最长单词元素下标

            m1 = i;//用来标记这个单词的大小

            break;

        }

    }

    for (i = 0; i < k; i++)

    {

        if (a[i] == min)

        {

            min = b[i];//最短单词元素下标

            m2 = i;

            break;

        }

    }

    //输出最长单词

    for (i = max; i < max + a[m1]; i++)

    {

        printf("%c", str[i]);

    }

    printf("\n");

    //输出最短单词

    for (i = min; i < min + a[m2]; i++)

    {

        printf("%c", str[i]);

    }

    printf("\n");

    return 0;

}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

dreamleaf 1年前 回复TA
您好,我提交代码一直得到91分,请问您知道测试点有哪些吗?