A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

取出一个字符中字母出现的次数。如:字符串:“abcdekka27qoq”,输入格式为:a(2)b(1)k(2)...

8 个回复

倒序浏览
package cross01;

import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Scanner;
import java.util.Set;
import java.util.TreeMap;

public class ExamTest7 {
        public static void main(String[] args) {
                Scanner sc = new Scanner(System.in);
                System.out.println("请输入一个字符串:");
                String str = sc.nextLine();
                char[] ch = str.toCharArray();// 转换成字符数组
                TreeMap<Character, Integer> map = new TreeMap<>();// 创建一个TreeMap
                for (char c : ch) {// 遍历
                        Character key = c;
                        Integer value = map.get(c);
                        if (value == null) {// 判断,如果值为空,则向集合中添加(key,1),如果不为空则添加(key,value+1)
                                map.put(key, 1);
                        } else {
                                map.put(key, value + 1);
                        }
                }
                // 遍历集合
                Set<Map.Entry<Character, Integer>> set = map.entrySet();
                Iterator<Entry<Character, Integer>> it = set.iterator();
                while (it.hasNext()) {
                        Map.Entry<Character, Integer> me = it.next();
                        Character key = me.getKey();
                        Integer value = me.getValue();
                        System.out.println(key + "(" + value + ")");// 按规定的格式输出
                }
        }

}

回复 使用道具 举报
楼上是标准答案
回复 使用道具 举报
String str="asddfgsdgdasdasdasd";
                HashMap<Character, Integer> hm=new HashMap<>();
                char [] ch=str.toCharArray();
                ArrayList<Character> al=new ArrayList<>();
                for (char c : ch) {
                        al.add(c);
                }
                int count =0;
                char now;
                while (al.size()>1) {
                        now=al.get(0);
                        for (int a1=0;a1<al.size();a1++) {
                                if(al.get(a1)==now){
                                        count++;
                                        al.remove(a1);
                                        a1--;
                                }
                        }
                        hm.put(now, count);
                        count=0;
                }
                Iterator<Map.Entry<Character,Integer>> it=hm.entrySet().iterator();
                Object next;
                while (it.hasNext()) {
                        next=it.next();
                        System.out.println(next);
                }
回复 使用道具 举报
简易版       
String str="asddfgsdgdasdasdasd";
                HashMap<Character, Integer> hm=new HashMap<>();
                char [] chArr=str.toCharArray();
                for (char ch : chArr) {
                        Integer value=hm.get(ch);
                        if(value==null)value=0;
                        hm.put(ch,value+1);
                }
                Iterator<Map.Entry<Character,Integer>> it=hm.entrySet().iterator();
                Object next;
                while (it.hasNext()) {
                        next=it.next();
                        System.out.println(next);
                }
               
回复 使用道具 举报
这个好像是考试题,我看过,当初没哟做出来
回复 使用道具 举报
Lonely_yu 发表于 2015-9-7 10:00
package cross01;

import java.util.Iterator;

很厉害啊 !
回复 使用道具 举报
回复 使用道具 举报
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马