Java: 求一个字符串string中每个字母出现的次数,然后记录在array a 中。
publicclassCount{privateStringx;privateint[]y=newint[40];:}...
public class Count
{
private String x;
private int [ ] y =new int [40];
:
} 展开
{
private String x;
private int [ ] y =new int [40];
:
} 展开
4个回答
展开全部
class Test{
/**
此方法实现统计字符串中字符个数逻辑,此方法返回Map集合,
key为字符,value为字符出现的次数
*/
public static Map<Character,Integer> countChar(String str){
char[] charArray=str.toCharArray(); //将字符串转换为字符数组
Map<Character,Integer> map=new HashMap<Character,Integer>(); //创建map对象用来存放数据
for(int i=0;i<charArray.length;i++){ //遍历该字符数组
Character key=charArray[i];
Integer va=map.get(key);
if(va!=null){
va+=1; //如果作为key的字符前面已经出现过,则出现次数va加1
}else{
va=1; //如果作为key的字符前面没有出现过,则出现次数va为1
}
map.put(key,va); //将字符极其出现的次数放进map集合,如果之前有,则覆盖
}
return map;
}
/**
main方法入口
*/
public static void main(String[] args){
String str="abcdbcdefABDABCD"; //需要统计的字符串
Map<Character,Integer> map=countChar(str); //调用方法
System.out.println(map);
}
}
给分吧,手写不容易
/**
此方法实现统计字符串中字符个数逻辑,此方法返回Map集合,
key为字符,value为字符出现的次数
*/
public static Map<Character,Integer> countChar(String str){
char[] charArray=str.toCharArray(); //将字符串转换为字符数组
Map<Character,Integer> map=new HashMap<Character,Integer>(); //创建map对象用来存放数据
for(int i=0;i<charArray.length;i++){ //遍历该字符数组
Character key=charArray[i];
Integer va=map.get(key);
if(va!=null){
va+=1; //如果作为key的字符前面已经出现过,则出现次数va加1
}else{
va=1; //如果作为key的字符前面没有出现过,则出现次数va为1
}
map.put(key,va); //将字符极其出现的次数放进map集合,如果之前有,则覆盖
}
return map;
}
/**
main方法入口
*/
public static void main(String[] args){
String str="abcdbcdefABDABCD"; //需要统计的字符串
Map<Character,Integer> map=countChar(str); //调用方法
System.out.println(map);
}
}
给分吧,手写不容易
展开全部
你可以这样做,将这个string的字符串放到一个字符数组中去,然后用循环遍历出其中的每一个字符,并将其放在一个新的list或者map中去,key就是在这个字符串中出现的字符,value就是用循环遍历出来出现的次数,这样不就拿到了吗!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个可以能达到你一半的要求,可以自己修改下
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
public class TestTwo {
public static void sop(Object obj) {
System.out.println(obj);
}
public static String CharCount(String str) {
char[] chs = str.toCharArray();// 将字符串转换为字符数组。
TreeMap<Character, Integer> tm = new TreeMap<Character, Integer>();
int count = 0;
for (int x = 0; x < chs.length; x++) {
if (!(chs[x] >= 'a' && chs[x] <= 'z')
|| (chs[x] >= 'A' && chs[x] <= 'Z'))
continue;
Integer value = tm.get(chs[x]);// 返回chs[x]键所对应的值Value.
if (value != null)
count = value;
count++;
tm.put(chs[x], count);
count = 0; // 每次循环前计数器清零
}
Set<Map.Entry<Character, Integer>> entrySet = tm.entrySet();
Iterator<Map.Entry<Character, Integer>> it = entrySet.iterator();
StringBuilder sb = new StringBuilder();
while (it.hasNext()) {
Map.Entry<Character, Integer> me = it.next();
Character ch = me.getKey();
Integer in = me.getValue();
sb.append(ch + "(" + in + ")");
}
return sb.toString();
}
public static void main(String[] args) {
String str = CharCount("aaa dfdasfa err");
sop(str);
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
char c = 'a';
int[] counts = new int['z' - 'a'];
System.out.print("your input :");
Scanner sc = new Scanner(System.in);
String line = sc.nextLine();
line = line.toLowerCase();
line = line.replaceAll("[^a-z]", "");
System.out.println(line);
char[] array = line.toCharArray();
for (int i = 0; i < array.length; i++) {
counts[array[i] - c]++;
}
System.out.println("char count:");
for (int i = 0; i < counts.length; i++) {
System.out.println((char) (c + i) + " : " + counts[i]);
}
}
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询