步骤分析

1、给出一串字符串,字符串中可以包含字母、数字、符号等等。

2、创建一个Map集合,key是字符串中的字符,value是字符的个数。

3、遍历字符串,获取每一个字符。

5、使用获取到的字符,去集合Map判断key(字符)是否存在。

6、假如key(字符)存在,那么该key对应的value数值增加1,即该字符的数量加一。

7、假如key(字符)不存在,value的值设为1,并将key-value添加到Map集合中。

8、遍历Map集合,输出每个字符个数的结果。

代码实现

创建一个CharNumber类,在类中定义keyValue方法,计算字符串中每个字符的个数

public class CharNumber {
/**
* 计算字符串中每个字符的个数
* @param string 要被计算字符个数的字符串
* @return <字符-个数> 的Map集合
*/
public static HashMap<Character, Integer> keyValue(String string) {
// 字符串转换为字符数组
char[] chars = string.toCharArray(); // 创建一个Map集合用来存放记录
HashMap<Character, Integer> hashMap = new HashMap<>(); // 遍历字符串,获取每一个字符
for (char c : chars) {
// 使用获取到的字符,去Map集合判断key是否存在
// 利用Map集合的containsKey()方法,判断key是否存在
// 如果存在 value ++,如果不存在 value = value
if (hashMap.containsKey(c)) {
// key存在,获取key对应的value,数值增加一,然后再更新到集合中
Integer value = hashMap.get(c);
value ++;
hashMap.put(c, value);
} else {
// key不存在,将key添加到Map集合中,且其对应的value为1
hashMap.put(c, 1);
}
}
return hashMap;
}
}

创建一个CharNumber类,在类中定义iteratorMap方法,遍历输出计算结果

public class CharNumber {
/**
* 遍历输出Map集合
* @param hashMap <字符-个数> 的Map集合
*/
public static void iteratorMap(HashMap<Character, Integer> hashMap) {
// 调用Map集合的entrySet()方法,获取集合Map的Key-Value,赋值给Set集合
Set<Map.Entry<Character, Integer>> set = hashMap.entrySet();
// 创建Set集合的迭代器
Iterator<Map.Entry<Character, Integer>> kvIterator = set.iterator();
// 迭代输出Set集合
// hasNext():是否存在下一个元素
// next():获取下一个元素
while (kvIterator.hasNext()) {
Map.Entry<Character, Integer> kv = kvIterator.next();
System.out.println("字符'" + kv.getKey() + "'的个数是:" + kv.getValue());
}
}
}

测试一下CharNumber类,随便输入一串字符串,计算每个字符的个数

public class DemoCharNumber {
public static void main(String[] args) {
Scanner scn = new Scanner(System.in);
System.out.print("请输入一个字符串:");
String string = scn.next();
CharNumber.iteratorMap(CharNumber.keyValue(string));
}
}
运行代码(注意,不能输入空格):
请输入一个字符串:dafsdaganjsda!!!!!!
字符'a'的个数是:4
字符'!'的个数是:6
字符's'的个数是:2
字符'd'的个数是:3
字符'f'的个数是:1
字符'g'的个数是:1
字符'j'的个数是:1
字符'n'的个数是:1

代码总和

CharNumber类

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set; public class CharNumber { public static HashMap<Character, Integer> keyValue(String string) {
char[] chars = string.toCharArray();
HashMap<Character, Integer> hashMap = new HashMap<>();
for (char c : chars) {
if (hashMap.containsKey(c)) {
Integer value = hashMap.get(c);
value ++;
hashMap.put(c, value);
} else {
hashMap.put(c, 1);
}
}
return hashMap;
} public static void iteratorMap(HashMap<Character, Integer> hashMap) {
Set<Map.Entry<Character, Integer>> set = hashMap.entrySet();
Iterator<Map.Entry<Character, Integer>> kvIterator = set.iterator();
while (kvIterator.hasNext()) {
Map.Entry<Character, Integer> kv = kvIterator.next();
System.out.println("字符'" + kv.getKey() + "'的个数是:" + kv.getValue());
}
}
}

DemoCharNumber类

// 测试

import java.util.Scanner;

public class DemoCharNumber {
public static void main(String[] args) {
Scanner scn = new Scanner(System.in);
System.out.print("请输入一个字符串:");
String string = scn.next();
CharNumber.iteratorMap(CharNumber.keyValue(string));
}
}

Java 利用Map集合计算一个字符串中每个字符出现的次数的更多相关文章

  1. 利用HashMap计算一个字符串中每个字符出现的次数

    问题描述:计算一个字符串中每个字符出现的次数 问题分析:每个字符串对应着它的次数,且字符串唯一不重复,这让我们想到了HashMap中的键值对. 1.使用Scanner获取字符串 2.遍历字符串,获取每 ...

  2. JAVA经典题--计算一个字符串中每个字符出现的次数

    需求:  计算一个字符串中每个字符出现的次数 思路: 通过toCharArray()拿到一个字符数组--> 遍历数组,将数组元素作为key,数值1作为value存入map容器--> 如果k ...

  3. 用es6的Array.reduce()方法计算一个字符串中每个字符出现的次数

    有一道经典的字符串处理的问题,统计一个字符串中每个字符出现的次数. 用es6的Array.reduce()函数配合“...”扩展符号可以更方便的处理该问题. s='abananbaacnncn' [. ...

  4. Java基础知识强化之集合框架笔记61:Map集合之统计字符串中每个字符出现的次数的案例

    1. 首先我们看看统计字符串中每个字符出现的次数的案例图解: 2. 代码实现: (1)需求 :"aababcabcdabcde",获取字符串中每一个字母出现的次数要求结果:a(5) ...

  5. 阶段1 语言基础+高级_1-3-Java语言高级_04-集合_08 Map集合_10_练习_计算一个字符串中每个字符出现的次数

  6. Hashtable集合 --练习题_计算一个字符串中每个字符出现次数

    Hashtable集合 java.util.Hashtable<K,V>集合 implements Map<K,V>接口  Hashtable:底层也是一个哈希表,是一个线程安 ...

  7. Java统计一个字符串中各个字符出现的次数

    相信很多人在工作的时候都会遇到这样一个,如何统计一个字符串中各个字符出现的次数呢,这种需求一把用在数据分析方面,比如根据特定的条件去查找某个字符出现的次数.那么如何实现呢,其实也很简单,下面我贴上代码 ...

  8. 计算一个字符串的每个字符出现的次数案例——Map集合

    其中,字符的包装类是Character;字符串包装类是String: 遍历字符串转换的数组,每个元素都是一个字符,看创建的这个集合有木有,一开始肯定是没有的其实,字符作为key,所以判断的是这个创建的 ...

  9. Java 13天基础 06天map集合小练习(黑马程序员) 统计字符串中每个字符出现的次数 (经典面试题)

    import java.util.HashMap; import java.util.Map; import java.util.Scanner; /** * 目标 : 输出一个字符串中每个字符出现的 ...

随机推荐

  1. H3C 根据子网数划分子网

  2. Webstorm 配置 Less编译

    配置less编译

  3. H3C查看、删除已经保存配置文件--用户图示(console)以上

    <H3C>display saved-configuration    //显示已经保存的内容 <H3C>reset saved-configuration      //删除 ...

  4. 裁剪nutch 8步骤

    裁剪nutch 8步骤

  5. iOS-NSNotificationCenter通知原理解析

    一.基本概念 NSNotification和NSNotificationCenter是使用观察者模式来实现的用于跨层传递消息. NSNotificationCenter采用单例模式. 二.基本实现 通 ...

  6. 关于js如果控制标签的字符长度

    js名字长度限定(如限制为50个字符,超过的显示...) var new_playerName = ""; jQuery(".translate").each( ...

  7. mysql中information_schema.views字段说明

    1.查看视图并不是查询视图数据,而是查看数据库中已经存在的视图的定义,查看视图必须要有SHOW VIEW权限,MySQL的数据库下的user表中存储这这个数据.查看视图的方法有:DESCRIBE,SH ...

  8. ArrayList、LinkedList、Vector、CopyOnWriteArrayList的区别和源码分析

    1. ArrayList ArrayList 是一个数组队列,相当于动态数组.与Java中的数组相比,它的容量能动态增长.它继承于AbstractList,实现了List, RandomAccess, ...

  9. Git安装--Windows

    Git安装配置 在使用Git前我们需要先安装 Git.Git 目前支持 Linux/Unix.Solaris.Mac和 Windows 平台上运行. Git 各平台安装包下载地址为:http://gi ...

  10. 【学习笔鸡】快速沃尔什变换FWT

    [学习笔鸡]快速沃尔什变换FWT OR的FWT 快速解决: \[ C[i]=\sum_{j|k=i} A[j]B[k] \] FWT使得我们 \[ FWT(C)=FWT(A)*FWT(B) \] 其中 ...