统计数组中的重复数据的数量

简介: 这篇文章总结了5种统计数组中重复数据数量的方法。方法1和4使用for循环和对象存储计数;方法2和5利用`reduce`函数,其中方法5是最简写形式;方法3是特定场景下的应用,针对特定值计数。所有方法最终都返回一个对象,键为数组元素,值为出现次数。

统计数组中的重复数据的数量

开发项目时,进行 行列合并时需要计算当前某值的出现次数,从而决定合并的行数,在搜集资料以及思考下做出如下总结

1、方法1

  1. 首先定义一个数组和空对象

     const arr = ['a', 'b', 'c', 'a', 'a', 'b', ''];
     let obj = {}
    
  2. 循环数组,把循环的数据定义为属性名,倘若未找到相关属性值,默认传1, 否则在原有的数字上加1

     arr.forEach(item => {
    
     obj[item] = (obj[item] + 1) || 1
    
     })
    
     console.log(obj)
    
  3. 打印obj内容如下
    在这里插入图片描述

2、方法2

  1. 首先定义一个数组

     const arr = ['a', 'b', 'c', 'a', 'a', 'b', ''];
    
  2. 对array.reduce 中的prev 赋值即可
    reduce 的第一个参数得到的是迭代计算后的效果,所以可以使用第一个参数实现简单的数组去重和排序等

     arr.reduce(function(prev, next){ 
    
             prev[next] = (prev[next] + 1) || 1;
    
             console.log( prev) 
    
         },{});
    
  3. 打印prev内容如下:
    在这里插入图片描述

3、方法3

  1. 简写reduce

     let counts = (arr, value) => arr.reduce((a, v) => v === value ? a + 1 : a + 0, 0);
    
     console.log('数组counts中"李"出现的次数是:'+counts(["李","李","设","弟","弟","生","生","李"],"李"));
    
  2. 输出结果为
```
结果:数组counts中"李"出现的次数是:3
```

4、方法4

  1. 不用reduce时:
     var arr = ["李","李","设","弟","弟","生","生","李"]; 
     function getRepeatNum(){ 
         var obj = {}; 
         for(var i= 0, l = arr.length; i< l; i++){ 
             var item = arr[i]; 
             obj[item] = (obj[item] +1 ) || 1; 
         } 
         return obj; 
     }
     console.log(getRepeatNum());
    
  2. 结果:{李: 3, 设: 1, 弟: 2, 生: 2}

    5、方法5

  3. 用reduce时
      var arr = ["李","李","设","弟","弟","生","生","李"]; 
      function getRepeatNum(){ 
          return arr.reduce(function(prev,next){ 
              prev[next] = (prev[next] + 1) || 1; 
              return prev; 
          },{}); 
      } 
      console.log(getRepeatNum());
    
  4. 结果:{李: 3, 设: 1, 弟: 2, 生: 2}
相关文章
|
4月前
|
JavaScript 前端开发
对数组元素出现次数进行统计
该文章介绍了如何使用JavaScript统计数组中每个元素的出现次数,包括通过创建对象和使用`Set`对象去重的方法。
43 2
对数组元素出现次数进行统计
|
7月前
|
存储 SQL 缓存
使用索引注意合理的数量
【6月更文挑战第9天】本文介绍数据库索引是提升数据检索速度的数据结构,通过减少磁盘访问提高性能。建议根据表的大小和使用频率谨慎创建索引,如核心表不超过7个索引,普通表不超过5个,小型表不超过3个。
113 3
使用索引注意合理的数量
|
8月前
|
人工智能 程序员 数据处理
Pandas数据处理4、DataFrame记录重复值出现的次数(是总数不是每个值的数量)
Pandas数据处理4、DataFrame记录重复值出现的次数(是总数不是每个值的数量)
110 0
Pandas数据处理4、DataFrame记录重复值出现的次数(是总数不是每个值的数量)
|
8月前
|
Java 测试技术
统计满足条件的子集个数
统计满足条件的子集个数
49 0
|
SQL 分布式计算 MaxCompute
一次性查询一张表所有字段的空值率
一次性查询一张表所有字段的空值率
1838 2
|
C语言 C++
1684. 统计一致字符串的数目
给你一个由不同字符组成的字符串 allowed 和一个字符串数组 words 。如果一个字符串的每一个字符都在 allowed 中,就称这个字符串是 一致字符串 。 请你返回 words 数组中 一致字符串 的数目。
102 0
|
关系型数据库 MySQL 索引
一个表中索引的数量是不是越多越好?
往InnoDB表新增数据时,都会基于主键给自动建立聚簇索引。 随着我们不停的在表里插入数据,会不停的在数据页里插入数据。一个数据页放满后,就会分裂成多个数据页,这时就需要索引页去指向各个数据页。
136 0
|
索引 Python
LeetCode 599. 两个列表的最小索引总和
假设Andy和Doris想在晚餐时选择一家餐厅,并且他们都有一个表示最喜爱餐厅的列表,每个餐厅的名字用字符串表示。
98 0
LeetCode 1684. 统计一致字符串的数目
给你一个由不同字符组成的字符串 allowed 和一个字符串数组 words 。
94 0

热门文章

最新文章