描述
计算字符串中含有的不同字符的个数。字符在 ASCII 码范围内( 0~127 ,包括 0 和 127 ),换行表示结束符,不算在字符里。不在范围内的不作统计。多个相同的字符只计算一次。数据范围: 1≤n≤500
例如,对于字符串 abaca 而言,有 a、b、c 三种不同的字符,因此输出 3 。
输入描述
输入一行没有空格的字符串。
输出描述
输出 输入字符串 中范围在(0~127,包括0和127)字符的种数。
示例1
输入:abc
输出:3
示例2
输入:aaa
输出:1
将字符串中的每个元素强制转化为ASCll码,作为新建数组的下标,数组的值代表字符串中每种元素的个数,最后遍历数组来统计共出现字符种类的数量。
C语言
#include <stdio.h> #include<string.h> int main() { char str[500]; scanf("%s",str); //存放128种字符的个数 int con[128]={0}; //以字符的ASCLL码作为下标存于数组中 for (int i=0; i<strlen(str);i++) { //一种字符第一次出现 if(con[(int)str[i]]==0) { con[(int)str[i]]=1; } //一种字符出现一次以上 else { con[(int)str[i]]+=1; } } //统计元素的种类 int count=0; for (int i=0; i<128;i++) { if(con[i]!=0) count++; } printf("%d",count); return 0; }
Java
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); String str=in.next(); //存放128种字符的个数 int[] index=new int[128]; //将字符串转化为字符数组,并遍历整个数组,x表示数组中的元素 for(char x:str.toCharArray()){ if(x=='\n') break; else { //一种字符第一次出现 if(index[x]==0) index[x]=1; //一种字符出现一次以上 else index[x]+=1; } } //统计不同字符数量 int count=0; for(int i=0;i<128;i++){ if(index[i]!=0) count++; } System.out.println(count); } }