博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
对 Java 集合的巧妙利用
阅读量:5066 次
发布时间:2019-06-12

本文共 2527 字,大约阅读时间需要 8 分钟。

 

  我们直接切入正题。首先大致介绍一下 Java 三大集合的一些特征:

  ①、ArrayList:底层采用数组结构,里面添加的元素有序可以重复。

  ②、HashSet:底层采用哈希表算法,里面添加的元素无序不可重复。

  ③、HashMap:底层也是采用哈希表算法,但是里面添加的元素是 key-value 的形式。key 不允许重复,value 可以。

 

  那么我们在日常编程中就可以好好利用这些集合的原理,简化我们的编程思路。

 

  一、如何统计一字符串中每个字符出现的次数?

  解析:给定一串字符串,统计每个字符出现的次数。那么最后统计出来的格式应该如下:

      a---num个

      b---num个

        ...

      j---num个等等

      很明显,这种格式首先第一个统计的字符是不能重复的,而出现的个数我们可以不用管。那么很容易联想到 Map 的集合原理,key-value。我们将统计的字符放在 Map<Character,Integer>中是一种很好的实现方式。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class CountCharTest {
     
    public static Map<Character, Integer> countChar(Map<Character, Integer> map,String str){
        //将所给的字符串解析为一个字符构造的数组
        char[] chars = str.toCharArray();
         
        for(char c : chars){
            if(map.containsKey(c)){
                int oldCount = map.get(c);
                map.put(c, oldCount+1);
            }else{
                map.put(c, 1);
            }
        }
         
        return map;
    }
 
    public static void main(String[] args) {
        String str = "afoiasfoffqefljflsda";
        //定义一个 Map 集合,用来存放统计的     字符--个数
        Map<Character, Integer> hashMap = new HashMap<>();
        System.out.println(countChar(hashMap,str));
        //{f=6, d=1, e=1, s=2, q=1, a=3, o=2, l=2, j=1, i=1}
    }
}

  补充:这里我们用来保存统计字符的是 HashMap 的实现类,这里打印出来的字符统计是无序的。如果我们想根据字符串给定的顺序有序的统计出来,可以使 LinkedHashMap

1
2
3
4
5
6
7
public static void main(String[] args) {
        String str = "afoiasfoffqefljflsda";
        //定义一个 Map 集合,用来存放统计的     字符--个数
        Map<Character, Integer> linkedHashMap = new LinkedHashMap<>();
        System.out.println(countChar(linkedHashMap,str));
        //{a=3, f=6, o=2, i=1, s=2, q=1, e=1, l=2, j=1, d=1}
    }

  如果想用 uicode 的编码顺序打印给定的字符串,那么我们使用 TreeMap 

1
2
3
4
5
6
7
public static void main(String[] args) {
        String str = "afoiasfoffqefljflsda";
        //定义一个 Map 集合,用来存放统计的     字符--个数
        Map<Character, Integer> treeMap = new TreeMap<>();
        System.out.println(countChar(treeMap,str));
        //{a=3, d=1, e=1, f=6, i=1, j=1, l=2, o=2, q=1, s=2}
    }

  

  

  二、给定一个数组,如何去掉重复的数据?

  解析:这个联想到集合的特定,我们就很容易想到用 Set 集合来解决。将数组中的元素都放到Set,然后将 Set 集合转变为数组就可以了。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
public class ClearRepeatTest {
     
    public static Integer[] clearRepeat(int [] array){
        Set<Integer> set = new HashSet<>();
        for(int i : array){
            set.add(i);
        }
        Integer[] newArray = set.toArray(new Integer[set.size()]);
        return newArray;
    }
     
     
    public static void main(String[] args) {
        //创建一个数组,可以看出 2和4 是重复的
        int [] array = {
1,2,3,4,8,2,5,4};
        Integer[] newArray = clearRepeat(array);
        for(Integer i : newArray){
            System.out.println(i);
        }
        //1 2 3 4 5 8
         
    }
 
}

  补充:同理我们可以 改变 Set 集合的实现类,hashSet 是无序的,我们可以会用 LinkedHashSet 保证既定顺序;TreeSet 保证自然顺序

转载于:https://www.cnblogs.com/123hll/p/6903344.html

你可能感兴趣的文章
NYOJ-613//HDU-1176-免费馅饼,数字三角形的兄弟~~
查看>>
graphite custom functions
查看>>
一个自己写的判断2个相同对象的属性值差异的工具类
查看>>
oracle连接的三个配置文件(转)
查看>>
Python内置函数(29)——help
查看>>
oracle导出/导入 expdp/impdp
查看>>
Objective - C基础: 第四天 - 10.SEL类型的基本认识
查看>>
Android TextView加上阴影效果
查看>>
《梦断代码》读书笔记(三)
查看>>
Java8 Lambda表达应用 -- 单线程游戏server+异步数据库操作
查看>>
[Unity3D]Unity3D游戏开发MatchTarget的作用攀登效果实现
查看>>
AngularJS学习篇(一)
查看>>
关于Xshell无法连接centos6.4的问题
查看>>
css3动画——基本准则
查看>>
输入月份和日期,得出是今年第几天
查看>>
pig自定义UDF
查看>>
Kubernetes 运维学习笔记
查看>>
spring security 11种过滤器介绍
查看>>
代码实现导航栏分割线
查看>>
大数据学习系列(8)-- WordCount+Block+Split+Shuffle+Map+Reduce技术详解
查看>>