1:js怎样得出数组中某个数据最大连续出现的次数
  1. var test=[,,,,,,,,,,,,,,,,] ;
  2. var j = ;
  3. var max = ;
  4. for(var i = ;i<test.length;i++){
  5. if(test[i] == ){
  6. j++;
  7. }else{
  8. if(j>max){
  9. max = j;
  10. }
  11. j = ;
  12. }
  13. }
  14. if(j>max) max = j ;
  15. alert(max);
2:消除一个数组里面重复的元素

JavaScript中indexOf函数方法是返回String对象内第一次出现子字符串的字符位置。使用方法:

strObj.indexOf(subString[,  startIndex])

//其中strObj是必选项。String 对象或文字
//subString是必选项。要在 String  对象中查找的子字符串。
//starIndex是可选项。该整数值指出在 String  对象内开始查找的索引。如果省略,则从字符串的开始
JavaScript中indexOf()函数方法返回一个整数值,指出  String 对象内子字符串的开始位置。如果没有找到子字符串,则返回 -1。如果 startindex 是负数,则 startindex  被当作零。如果它比最大的字符位置索引还大,则它被当作最大的可能索引。
  1. var arr1 =[,,,,,,,,,]
  2. var arr2 = [];
  3. for(var i = ,len = arr1.length; i< len; i++){
  4. if(arr2.indexOf(arr1[i]) === -){
  5. arr2.push(arr1[i]);
  6. }
  7. }
  8. console.log(arr2);

3:js查找数组里面的重复的元素

1》for循环indexof()

  1. var a=[, , , , , , ,,,,,,,,];
  2.  
  3. var b=[];
  4.  
  5. for (var i =; i <a.length; i++) {
  6.  
  7. if(b.indexOf(a[i])==- && a.indexOf(a[i])!==a.lastIndexOf(a[i])){
  8.  
  9. b.push(a[i]);
  10.  
  11. }
  12.  
  13. }
  14.  
  15. console.log(b);

2》先进行排序,然后就是其中的两两的比较,如果是相等而且还不存在b数组我们将其放在b数组里面

  1. var a=[, , , , ,,,,];
  2.  
  3. var b =[];
  4.  
  5. a.sort(function(a,b){
  6.  
  7. return a-b;
  8.  
  9. });
  10.  
  11. for (var i = ; i <a.length; i++) {
  12.  
  13. if(a[i]==a[i-] && b.indexOf(a[i])==-){
  14.  
  15. b.push(a[i]);
  16.  
  17. }
  18.  
  19. }
  20.  
  21. console.log(b);

3》reduce()方法去重

  1. var arr = [,,,,,,];
  2. var newArr = arr.reduce(function (prev, cur) {
  3. console.log(prev,cur)
  4. prev.indexOf(cur) === - && prev.push(cur);
  5. return prev;
  6. },[]);
  7. console.log(newArr)

3:js判断某元素出现的次数

重点有三个:
1,通过嵌套for循环,把数组的每一项,跟整个数组中的所有项,比较一遍;
2,通过if判断,如果有相等的项,count++,并把相等的项置为-1,这样可以判断等于-1的就是重复的,就不再加入新数组了;
3,用if判断!=-1,决定是否加入新数组中,返回。

  1. function arrCheck(arr){
  2. var newArr = [];
  3. for(var i=;i<arr.length;i++){
  4. var temp=arr[i];
  5. var count=;
  6. for(var j=;j<arr.length;j++){
  7. if(arr[j]==temp){
  8. count++;
  9. arr[j]=-;
  10. }
  11. }
  12. if(temp != -){
  13. newArr.push(temp+":"+count)
  14. }
  15. }
  16. return newArr;
  17. }
  18.  
  19. arrCheck([,,,,]);
  20.  
  21. console.log(arrCheck([,,,,]));

我们可以运用reduce来解决这个问题。

我们在reduce的第二个参数里面初始了回调函数第一个参数的类型和值,将字符串转化为数组,那么迭代的结果将是一个对象,对象的每一项key值就是字符串的字母。运行感受一下吧。

  1. var arrString = 'abcdaabc';
  2.  
  3. sum = arrString.split('').reduce(function(res, cur) {
  4. res[cur] ? res[cur] ++ : res[cur] =
  5. return res;
  6. }, {})
  7. console.log(sum)

JS实现找出字符串中出现最多的字符和次数

  1. var str = "zhaochucichuzuiduodezifu";
  2. var o = {};
  3. //遍历str,统计每个字符出现的次数
  4. for (var i = , length = str.length; i < length; i++) {
  5. //当前第i个字符
  6. var char = str.charAt(i);
  7. //char就是对象o的一个属性,o[char]是属性值,存储出现的次数
  8. if (o[char]) { //如果char属性存在,属性值+1
  9. o[char]++; //次数加1
  10. } else { //char属性不存在为1(即字符第一次出现)
  11. o[char] = ; //若第一次出现,次数记为1
  12. }
  13. }
  14. //输出的是完整的对象,记录着每一个字符及其出现的次数
  15. //输出{a:1, c:3, d:2, e:1, f:1, h:3, i:3, o:2, u:5, z:3}
  16. console.log(o);
  17. //遍历对象,找到出现次数最多的字符和次数
  18. var max = ; //存储出现次数最多的次数
  19. var maxChar = null; //存储出现次数最多的字符
  20. for (var key in o) {
  21. if (max < o[key]) {
  22. max = o[key]; //max始终储存次数最大的那个
  23. maxChar = key; //那么对应的字符就是当前的key
  24. }
  25. }
  26. console.log("最多的字符是" + maxChar);
  27. console.log("出现的次数是" + max);
  1.  

计算数组中的最大值和最小值

  1. var arr = [,,,,,,];
  2. //假设法
  3. //假设数组中第一个数就是最大值
  4. var max = arr[];
  5. //假设数组中第一个数就是最小值
  6. var min = arr[];
  7. //用数组中后面的数依次和第一个数做比较 如果假设不成立 就改变max值
  8. for( var i = ; i < arr.length ; i++ ){
  9. if( arr[i] > max ){//最大值判断
  10. max = arr[i];//如果假设不成立 就改变max的值
  11. }
  12. if( arr[i] < min ){//最小值判断
  13. min = arr[i];//如果假设不成立 就改变min的值
  14. }
  15. }
  16.  
  17. alert("数组中 的最大值是:" + max);
  18. alert("数组中 的最小值是:" + min);

在Array的原型上实现数组的去重

  1. //norepeat 方法名
  2. Array.prototype.norepeat = function(){
  3. // 定义一个空数组 取出原数组中的每一个数 判断这个数在新数组中是否存在 如果不存在就存入到新数组中
  4. var brr = [];
  5. //原数组-- 用 this表示
  6. for( var i = ; i < this.length ; i++ ){
  7. if( brr.indexOf( this[i] ) == - ){
  8. brr.push( this[i] );
  9. }
  10. }
  11. return brr;
  12. }
  13. var arr = new Array(,,,,,,,);//原数组
  14. var arr2 = new Array(,,,,,);//原数组
  15. alert( arr2.norepeat() );

// 写一个函数,将数组中id相同的元素去重

  1. var arr = [{id:,name:'aa'},{id:,name:'aa'},{id:,name:'cc'},{id:,name:'dd'}]
  2.  
  3. 考察点: js基础知识的掌握
  4.  
  5. 解法一:
  6.  
  7. //数组各种方法的应用
  8.  
  9. function deWeight(arr,initArr=[]) {
  10.  
  11. arr.forEach(item=>{
  12.  
  13. let isFind = initArr.find(cell=> cell.id === item.id)
  14.  
  15. if(!isFind) {
  16.  
  17. initArr.push(item)
  18.  
  19. }
  20.  
  21. })
  22.  
  23. return initArr
  24.  
  25. }

如果您觉得文章有用,可以打赏个咖啡钱

每天成长一点点

js怎样得出数组中某个数据最大连续出现的次数的更多相关文章

  1. js限制输入数字能输入小数点,js定义数组,js往数组中添加数据,js将字符型转为数字型,除法结果保留两位小数——js小测:计算比赛得分

    一个朋友跟我说要去给某个比赛算分: 规则:去掉最低分最高分求平均分: 最近在学习大数据可视化——图谱,用到js一些东西,所以今天就用js练练 用到知识点: js限制输入数字能输入小数点,js定义数组, ...

  2. 关于iOS去除数组中重复数据的几种方法

    关于iOS去除数组中重复数据的几种方法   在工作工程中我们不必要会遇到,在数组中有重复数据的时候,如何去除重复的数据呢? 第一种:利用NSDictionary的AllKeys(AllValues)方 ...

  3. php去除数组中重复数据

    <?php /** * 去除数组中重复数据 * by www.jbxue.com **/ $input = array("a" => "green" ...

  4. php获取数组中重复数据的两种方法

    分享下php获取数组中重复数据的两种方法. 1,利用php提供的函数,array_unique和array_diff_assoc来实现 <?php function FetchRepeatMem ...

  5. C语言一维数组中的数据随机排列

    #include <stdio.h>#include <stdlib.h> void randomlize(int *a, int n){        int i = 0,j ...

  6. PHP如何将多维数组中的数据批量插入数据库?

    PHP将多维数组中的数据批量插入到数据库中,顾名思义,需要用循环来插入. 1.循环insert into 语句,逐渐查询 <?php /* www.qSyz.net */ @mysql_conn ...

  7. C语言:将带头节点的单向链表结点域中的数据从小到大排序。-求出单向链表结点(不包括头节点)数据域中的最大值。-将M*N的二维数组中的数据,按行依次放入一维数组,

    //函数fun功能是将带头节点的单向链表结点域中的数据从小到大排序. //相当于数组的冒泡排序. #include <stdio.h> #include <stdlib.h> ...

  8. jQuery写省级联动列表,创造二维数组,以及如何存/调用二维数组中的数据

    jQuery写省级联动列表,创造二维数组来存放数据,然后通过each来遍历调用,通过creatTxtNode创建文本节点,通过createElement创建标签option,在通过append将文本写 ...

  9. js map()处理数组和对象数据

    之前的文章梳理了JS数组与对象属性的遍历方法,本文介绍专门用以遍历并处理数据的map()方法. 一.原生map() map()是数组的一个方法,它创建一个新数组,其结果是该数组中的每个元素都调用一个提 ...

随机推荐

  1. 001Spring Boot中使用MongoDB

    01.下载MongoDB 点击标题链接,下载windows可用的MongoDB. 02.解压 将下载的压缩包放入C盘根目录(根据自己需要调整目录)---->解压到当前文件夹---->重命名 ...

  2. 文本(TextView)

    今天给大家介绍一下简单的文本. 首先我们看下TextView的继承关系和一些基本的属性: xml文件如下: <?xml version="1.0" encoding=&quo ...

  3. 网络I/O虚拟化,SR-IOV技术

    1.简介 网络I/O虚拟化是服务器虚拟化技术的重要组成部分,在服务器虚拟化技术领域,计算虚拟化(如CPU和内存虚拟化)已经日趋成熟,但是,网络I/O虚拟化技术的发展相对比较滞后.当前,主流的网络I/O ...

  4. 深入理解C++中的初始化

    C++经过这么多年的发展,已然成了一种文化和艺术,而这种艺术和文化并不是C++所固有的,是C++在各个方面的应用的总结和艺术化的结果.C++看起来比较复杂,但是深入其中你会发现C++是那么优美而富有哲 ...

  5. 海量数据处理面试题(1) 找出两文件种包含的相同的url

    问题:给定a.b两个文件,各存放50亿个url,每个url各占64字节,内存限制是4G,让你找出a.b文件共同的url? 分析:50亿个url,每个url64字节,就是320G,显然是无法一次读入内存 ...

  6. 初始python(三)

    1. 循环 if, while, forbreak : 结束整个循环continue :跳出当前这次循环,但不结束整个循环else :结束整个循环后才执行,不能与break合用,但可以与continu ...

  7. Shortest Paths

    最短路径 APIs 带权有向图中的最短路径,这节讨论从源点(s)到图中其它点的最短路径(single source). Weighted Directed Edge API 需要新的数据类型来表示带权 ...

  8. c++计算器后续(3)

    自娱自乐: 本来只是想改改第二次的代码规范的,然后好像把原来的代码玩坏了,真是尴尬...然后大概是又发现了一些东西.以上. main的参数: 大概是说main函数的括号里是可以带参数的,写成这个样子: ...

  9. iOS中 Proxy和的delegate区别

    在ios中使用proxy代理模式,经常容易和delegate委托模式混淆. 委托模式(delegate),是简单的强大的模式,可让一个对象扮演另外对象的行为.委托对象保持到另外对象的引用,并在适当的时 ...

  10. IOS Charles(代理服务器软件,可以用来拦截网络请求)

    什么是Charles Charles是一款代理服务器软件,可以用来拦截网络请求 利用Charles能得知大部分公司app的数据来源和数据格式 下载地址:http://www.charlesproxy. ...