比如“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集合, 没有的话可以用计数器的思想