一道很不错的Java数组练习题
这道题要求我们在控制台输入一行字符,统计每种字符出现的次数,然后把这个次数输出。那么,根据题干来看,这道题对数组的考查力度是非常大的。
我们可以用定义一个二维数组的方式,为我们输入的字符串分配存储空间。
import java.util.Scanner;
public class FindCharTimes {
public static void main(String[] args) {
System.out.println("请输入一个字符串:");
String str = new Scanner(System.in).nextLine();
//用一个二维数组存放字符和对应的字数
//用数组的缺点是空间浪费 可以用map 或别的代替这里就用数组简单点
int arr[][] = new int[2][str.length()];
for(int i=0;i<str.length();i++){
boolean chExist = false;//字符是否存在标志
for(int j=0;j<str.length();j++){
if(str.charAt(i)==arr[0][j]){
arr[1][j]++;
chExist = true;
}
}
//全部循环完成后,如果存在,数目加1,存在标志变为true,如果标志还是false则把这个字符加到数组里
if(!chExist){
arr[0][i]=str.charAt(i);
arr[1][i]=1;
}
}
for(int k=0;k<str.length();k++){
if(arr[0][k]!=0){
System.out.println("字符"+(char)arr[0][k]+"的数目为"+arr[1][k]);
}
}
}
}
接下来我们运行一下
看看结果
妥妥的
小弟不才,还请诸位大神多多指教