C语言:统计字符串中字符的种类

比如“AaHhsdjDNS”这个字符串 一共有6种字符
大写小写归为一种 这种到底咋写 没一点思路 各位大佬给点建议。。。。

如果问题得到解决,请点我回答左上角的采纳和向上的箭头,谢谢

#include "stdio.h"

int main()
{
    int letter = 0;
    int digit = 0;
    int space = 0;
    int others = 0;
    char buf[100];
    int ln[26];
    for (int i = 0; i < 26; i++) ln[i] = 0;
    gets(buf);
    int i = 0;
    while (buf[i] != '\0')
    {
        if (buf[i] >= 'a' && buf[i] <= 'z')
        {
            ln[buf[i] - 'a']++;
            letter++;
        }
        else if (buf[i] >= 'A' && buf[i] <= 'Z')
        {
            ln[buf[i] - 'A']++;
            letter++;
        }
        else if (buf[i] >= '0' && buf[i] <= '9')
            digit++;
        else if (buf[i] == ' ')
            space++;
        else
            others++;
        i++;
    }
    int total = i - 1;
    printf("L=%d D=%d S=%d O=%d T=%d\n", letter, digit, space, others, total);
    for (int i = 0; i < 26; i++)
    {
        if (ln[i])
            printf("%c: %d\n", 'A' + i, ln[i]);
    }
    return 0;
}

图片说明

先全部转换成小写,
然后把它切分成字符数组,
定义一个set无序集合
遍历这个数组, 全部存入set集合中
种类就等于这个set的大小

注:java的思路
不知道c有没有set集合, 没有的话可以用计数器的思想