黑马程序员技术交流社区
标题: 取出一个字符中字母出现的次数 [打印本页]
作者: 华尐 时间: 2015-9-6 23:30
标题: 取出一个字符中字母出现的次数
取出一个字符中字母出现的次数。如:字符串:“abcdekka27qoq”,输入格式为:a(2)b(1)k(2)...
作者: Lonely_yu 时间: 2015-9-7 10:00
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 + ")");// 按规定的格式输出
}
}
}
作者: 疯疯疯疯疯子 时间: 2015-9-7 11:00
楼上是标准答案
作者: purgatory 时间: 2015-9-7 11:26
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);
}
作者: purgatory 时间: 2015-9-7 12:34
简易版
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);
}
作者: mah707 时间: 2015-9-7 12:39
这个好像是考试题,我看过,当初没哟做出来
作者: 华尐 时间: 2015-9-7 23:24
很厉害啊 !
作者: 华尐 时间: 2015-9-7 23:41


作者: 华尐 时间: 2015-9-8 00:40

欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |