黑马程序员技术交流社区

标题: 统计字符串中各个小写字母出现的次数 [打印本页]

作者: 先小涛    时间: 2013-4-20 09:28
标题: 统计字符串中各个小写字母出现的次数
本帖最后由 先小涛 于 2013-4-21 12:17 编辑

输入一串小写字母字符串,统计各个字母的个数,并按如下两个图示打印输出
可以用“*”的个数来表示长度,x和y两方向的直线和箭头可以不必打印输出。

捕获.PNG (11.4 KB, 下载次数: 8)

捕获.PNG

作者: vicoooo    时间: 2013-4-20 10:03
  1. package test;

  2. import java.util.Iterator;
  3. import java.util.Map;
  4. import java.util.Map.Entry;
  5. import java.util.Scanner;
  6. import java.util.Set;
  7. import java.util.TreeMap;
  8. /**
  9. * 统计字符串相同字符的长度并打印
  10. * @author fjg
  11. *
  12. */
  13. public class Test {

  14.         public static void main(String[] args) {
  15.                 Scanner input = new Scanner(System.in); //使用Scanner接受从键盘的输入
  16.                 System.out.println("请输入一段字符:");
  17.                 String str = input.nextLine(); //从键盘接受输入的数据

  18.                 Map<Character,Integer> tree = new TreeMap<Character,Integer>();//利用TreeMap来保存某个字符出现的次数
  19.                
  20.                 for(int i=0;i<str.length();i++){
  21.                 char ch = str.charAt(i);
  22.                 //如果第一次出现,则初始为1
  23.                 if(!tree.containsKey(ch)){
  24.                 tree.put(ch, 1);
  25.                 }
  26.                 else{
  27.                 int auto = tree.get(ch)+1; //如果在容器中已存在,则在原来的基础上+1
  28.                 tree.put(ch, auto);
  29.                 }
  30.                 }

  31.                 // 使用Iterator,方便遍历输出
  32.                 Iterator<Character> iter = tree.keySet().iterator();
  33.                 while(iter.hasNext())
  34.                 {
  35.                 //获得字符对象信息
  36.                 char temp = iter.next();

  37.                 //输出每个字符出现的次数
  38.                 //System.out.println("字母'"+temp+"' 出现"+tree.get(temp)+"次。");
  39.                 System.out.print(temp);
  40.                 for(int i=0;i<tree.get(temp);i++){
  41.                         System.out.print("*");
  42.                 }
  43.                 System.out.println();
  44.                 }
  45.                

  46.                 }
  47. }
复制代码
请输入一段字符:
sadfadsfa
a***
d**
f**
s**
作者: vicoooo    时间: 2013-4-20 10:51
  1. package test;

  2. import java.util.ArrayList;
  3. import java.util.Collections;
  4. import java.util.Iterator;
  5. import java.util.List;
  6. import java.util.Map;
  7. import java.util.Map.Entry;
  8. import java.util.Scanner;
  9. import java.util.Set;
  10. import java.util.TreeMap;
  11. /**
  12. * 统计字符串相同字符的长度并打印
  13. * @author fjg
  14. *
  15. */
  16. public class Test {

  17.         public static void main(String[] args) {
  18.                 Scanner input = new Scanner(System.in); //使用Scanner接受从键盘的输入
  19.                 System.out.println("请输入一段字符:");
  20.                 String str = input.nextLine(); //从键盘接受输入的数据

  21.                 Map<Character,Integer> tree = new TreeMap<Character,Integer>();//利用TreeMap来保存某个字符出现的次数
  22.                
  23.                 for(int i=0;i<str.length();i++){
  24.                 char ch = str.charAt(i);
  25.                 //如果第一次出现,则初始为1
  26.                 if(!tree.containsKey(ch)){
  27.                 tree.put(ch, 1);
  28.                 }
  29.                 else{
  30.                 int auto = tree.get(ch)+1; //如果在容器中已存在,则在原来的基础上+1
  31.                 tree.put(ch, auto);
  32.                 }
  33.                 }

  34.                 // 使用Iterator,方便遍历输出
  35.                 Iterator<Character> iter = tree.keySet().iterator();
  36.                 List<Integer> list = new ArrayList<Integer>();
  37.                
  38.                 while(iter.hasNext()){
  39.                 //获得字符对象信息
  40.                 char temp = iter.next();

  41.                
  42.                 System.out.print(temp);
  43.                 list.add(tree.get(temp));       
  44.                
  45.                 }
  46.                 System.out.println();
  47.                 int max = Collections.max(list);
  48.                 for(int i=0;i<max;i++){
  49.                         for(int a=0;a<=list.size();a++){
  50.                                 if(i<a)
  51.                                         System.out.print("*");
  52.                         }
  53.                         System.out.println();
  54.                 }
  55.                
  56.                                
  57.         }
  58. }
复制代码
请输入一段字符:
aaabbc
abc
***
**
*
作者: vicoooo    时间: 2013-4-20 11:12
上面的有点错误。
  1. System.out.println();
  2.                 int max = Collections.max(list);
  3.                 for(int i=1;i<=max;i++){
  4.                         for(int a : list){
  5.                                 //System.out.print(a);
  6.                                 if(i<=a)
  7.                                         System.out.print("*");
  8.                                 else
  9.                                         System.out.print(" ");
  10.                         }
  11.                         System.out.println();
  12.                 }
复制代码

作者: vicoooo    时间: 2013-4-20 11:15
vicoooo 发表于 2013-4-20 10:51
请输入一段字符:
aaabbc
abc

代码的自己写才能记住呢。把星号打印到字母上方稍微麻烦一点,不过逻辑是一样的。
作者: 黄玉昆    时间: 2013-4-21 12:16
如果问题未解决,请继续追问,如果问题解决了,请将问题分类改为“已解决”,谢谢




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