第二十一题
思路:一开始N使用的数据类型是int,发现第三个测试点不能通过,发现N是位数不超过1000位,因此没有数字的数据类型可以存储N,只能用字符串来存储。所以要循环遍历输入的字符串,获取到每一个位置上的数字,获取到数字(char类型的数字为ASCII码需要减去48转换成数字)后在计算数字个数的数组中加一。最后再把存放个数的数组中,个数不等于0的数字个数打印出来。
#include <stdio.h>
#include <string.h>
int main()
{
int i, len;
char N[1000];
int A[10] = {
0};
scanf("%s", N);
len = strlen(N);
for(i=0; i<len; ++i){
if(N[i] == '0') A[0]++;
else if(N[i] == '1') A[1]++;
else if(N[i] == '2') A[2]++;
else if(N[i] == '3') A[3]++;
else if(N[i] == '4') A[4]++;
else if(N[i] == '5') A[5]++;
else if(N[i] == '6') A[6]++;
else if(N[i] == '7') A[7]++;
else if(N[i] == '8'