参考代码如下:

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

int main(void)
{
    char str[100];
    gets(str);

    char* words[20]; //存放分割的字符型指针
    int idx = 0;

    //以空格符分割字符串,存放至字符指针数组中
    char *token = strtok(str, " ");
    while (token != NULL)
    {
        words[idx++] = token;
        token = strtok(NULL, " ");
    }

    //将该字符指针数组各元素所指向的字符串进行比较并排序
    int i, j;
    for (i = 0; i < idx - 1; i++)
    {
        for (j = i + 1; j < idx; j++)
        {
            if (strcmp(words[i], words[j]) > 0)
            {
                char *tmp = words[i];
                words[i] = words[j];
                words[j] = tmp;
            }
        }
    }

    int num = 0;
    for (i = 1; i < idx; i++)
    {
        if (strcmp(words[i], words[i - 1]) != 0)
            num++;
    }

    if (num != 0)
        printf("%d\n", num + 1);
    else
        printf("%d\n", num);

    return 0;
}


点赞(2)
 

0.0分

1 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论