数组(I) - 网络统计学(11)(数组 算法)
myzbx 2025-07-01 22:12 6 浏览
数组是将相同类型的数据按照特定顺序组合在一起的集合。其中,每个独立的变量都被称为数组元素,有时也会被称作下标变量。而用于区分各个数组元素的数字编号,则被称为下标。
通常各种计算机编程语言都具备一定的数值运算能力,网页脚本Javascript语言具有强大和灵活多样的数组处理功能,充分利用JS数组编程知识可以解决几乎所有网络统计学方法。
1、一维数组和二维数组相互转换
一维数组和二维数组是编程中的基本数据结构,用于存储和处理数据,当然也适用于统计数据处理。一维数组是一个线性的数据结构,它包含一组有序的元素,每个元素可以通过索引访问。一维数组通常用一对方括号表示,里面的元素用逗号分隔,
例如:
webTJ.clear(); //清空屏幕
arr = [1, 2, 3, 4, 5] //定义一维数组arr
arr[2] = 10 //修改第3个元素(因为索引从0开始)
webTJ.display(arr,1); //以矩阵方式显示数组变量arr
注:打开网页“
http://www.galaxystatistics.com/webTJX.html”运行JS脚本,参见本地数据导入和转换 - 网络统计学(10)
二维数组是一个表格形式的数据结构,它包含多行多列的元素,每个元素可以通过两个索引(行和列)访问。二维数组通常用两个嵌套的方括号表示,例如:
webTJ.clear(); //清空屏幕
arrs = [[1, 2], [3, 4], [5, 6]] //定义一维数组arrs
arrs[1][0] = 10 //数组中的第2行第1列的元素(第1行、列的索引是0)
webTJ.display(arrs,1); //以矩阵方式显示数组变量arrs
在数学和统计学中,可以用一维数组表示1行或1列矩阵(向量),用二维数组表示m×n阶矩阵。
I、一维数组转换为二维数组
【语法】
// 函数
webTJ.Array.getArrsfromArr(arr, col);
//参数
【arr, col】
【一维数组, 二维数组列数】
【代码】
webTJ.clear();
var oArr=[1, 2, 3, 8, 9, 4, 5, 6, 7, 3, 5, 2];
var oArrs=webTJ.Array.getArrsfromArr(oArr,3); //将一维数组转换为二维数组(3列)
webTJ.display(oArrs,1); //以矩阵方式显示数组变量oArrs1
var oArrs1=webTJ.Array.getArrsfromArr(oArr,2); //将一维数组转换为二维数组(2列)
webTJ.display(oArrs1,1);
【显示效果】
II、二维数组转换为一维数组
【语法】
// 函数
webTJ.Array.getArrfromArrs(arrs);
//参数
【arrs】
【二维数组】
【代码】
webTJ.clear();
var oArrs=[[1,20],[1,2],[3,4],[5,6]];
var oArr=webTJ.Array.getArrfromArrs(oArrs); //将二维数组转换为一维数组并赋值给变量oArr
webTJ.display(oArr, 0); //显示一维数组(1,20,1,2,3,4,5,6)
webTJ.display(oArr.length, 0); //显示数组元素个数(8)
webTJ.display(oArr[6], 0); //数组第7个元素(5)
2、一维数组排序
I、数值型
【语法】
// 函数
webTJ.Array.getNArrSort(arr, k);
//参数
【arr, k】
【一维数组, 排序类型】
注:k = 0 升序、k=1 降序、k=2 乱序
【代码】
webTJ.clear();
var oArr=[3,2,5,1,2,5,4,3,3,1,2,4,2,1,1,5,4,1,3,1];
var oSrr=webTJ.Array.getNArrSort(oArr,0); //升序排序
webTJ.display(oSrr,0);
oSrr=webTJ.Array.getNArrSort(oArr,1); //降序排序
webTJ.display(oSrr,0);
oSrr=webTJ.Array.getNArrSort(oArr,2); //乱序排序
webTJ.display(oSrr,0);
II、字符型
【语法】
// 函数
webTJ.Array.getSArrSort(arr, k);
//参数
【arr, k】
【一维数组, 排序类型】
注:k = 0 升序、k = 1 降序、k = 2 乱序
【代码】
webTJ.clear();
var oTxt="d,v,j,r,h,n,m,s,v,l,q,f,x,g,p,c,t,i,u,o,k,w,e,b,z,a";
var oArr=webTJ.getArr(oTxt,","); //将字符串oTxt转换为数组oArr
var oSrr=webTJ.Array.getSArrSort(oArr,0); //将一维字符型数组按升序排序
webTJ.display(oSrr,0);
oSrr=webTJ.Array.getSArrSort(oArr,1); //将一维字符型数组按降序排序
webTJ.display(oSrr,0);
oSrr=webTJ.Array.getSArrSort(oArr,2); //将一维字符型数组按乱序排序
webTJ.display(oSrr,0);
3、二维数量型数组排序
I、数值型
【语法】
// 函数
webTJ.Array.getNArrsSort(arrs, k, c);
//参数
arrs, k, c】
【二维数组, 排序类型, 列】
注:k = 0 升序、k = 1 降序、k = 2 乱序
【代码】
webTJ.clear();
var oArrs=[[3,2,5,1],[2,5,4,3],[3,1,2,4],[2,1,1,5],[4,1,3,1]];
webTJ.display(oArrs,1);
var oSrrs=webTJ.Array.getNArrsSort(oArrs,0,2); //数组按升序对第3列进行排序
webTJ.display(oSrrs,1);
注:二维数组排序是处理表格数据的有利工具
II、字符型
【语法】
## 函数
webTJ.Array.getSArrsSort(arrs, k, c);
##参数
【arrs, k, c】
【二维数组,排序类型,列】
注:k = 0 升序、k = 1 降序、k = 2 乱序
【代码】
webTJ.clear();
var oTxt="e:2:g:r:p,t:b:3:c:o,j:a:1:a:k,l:m:d:4:h";
var oArrs=webTJ.getArrs(oTxt,",",":");
webTJ.display(oArrs,1);
var oSrrs=webTJ.Array.getSArrsSort(oArrs,0,1); //数组第2列按降序排序
webTJ.display(oSrrs,1);
4、数组量化
【语法】
// 函数
webTJ.Array.getQuantify(arrs);
//参数
【arrs】
【二维数组】
注:有时数组元素为数字字符(数字加引号,如"23"),可以用该函数加以量化后进行运算。对于由数字型字符转换来的数值,通常需要量化后进行统计运算
【代码】
webTJ.clear();
var oArrs=[
["3","2","3","1"],
[2,"5",4,3],[3,1,2,4],
[2,1,1,5],[4,1,3,1]];
oArrs=webTJ.Array.getQuantify(oArrs);
webTJ.display(oArrs,1);
5、生成均匀分布数组
【语法】
## 函数
webTJ.Array.getUniform(size, a, b, deci);
##参数
【size, a, b, deci】
【样本量, 下限, 上限, 保留小数】
【代码】
webTJ.clear();
var oArr=webTJ.Array.getUniform(50,30,100,2); //生成50个[30, 100]的随机数(保留2为小数)
webTJ.display(oArr,0);
6、生成正态分布数组
【语法】
// 函数
webTJ.Array.getNormal(size, mesn, sd, deci);
//参数
【size, mesn, sd, deci】
【样本量, 均值, 标准差, 保留小数】
【代码】
webTJ.clear();
var oArr=webTJ.Array.getNormal(50,100,10,2);
webTJ.display(oArr,0);
7、按频数和样本数量生成模拟样本数组
【语法】
// 函数
webTJ.Array.getRDrr(arrs, size);
// 参数
【arrs, size】
【指标频数数组,样本量】
注:按指定频数和样本量生成模拟样本在管理系统模拟中被广泛运用。该函数为复合函数,返回模拟样本和频数两个数组
【代码】
webTJ.clear();
var oPrrs=[["A",12],["B",23],["C",15],["D",34],["E",54],["F",67],["G",88],["H",65],["I",32],["J",14]];
var oArrs=webTJ.Array.getRDrr(oPrrs,100); //生成模拟样本数组
webTJ.display(oArrs[0],0); //显示模拟样本数组
webTJ.display(oArrs[1],1); //显示频数数组
8、提取不重复元素及频数和频率
【语法】
// 函数
webTJ.Array.getUnique(arr);
// 参数
【arr】
【一维数组】
注:返回数组列分别为指标项、频数、累计数、频率、分布概率
【代码】
webTJ.clear();
var oSrr=webTJ.Array.getUniform(100,30,100,0); //生成100个30-100的均匀分布随机数整数
webTJ.display(oSrr,0);
var oArrs=webTJ.Array.getUnique(oSrr); //提取数组唯一项及频数和频率
webTJ.show(oArrs,2); //数组按表格形式显示
webTJ.display(oArrs,1); //数组按矩阵形式显示
本文中所有的样例代码都已经过在线工具“
http://www.galaxystatistics.com/webTJX.html”的运行验证。
相关推荐
- C语言速成之数组:C语言数据处理的核心武器,你真的玩透了吗?
-
程序员Feri一名12年+的程序员,做过开发带过团队创过业,擅长Java、鸿蒙、嵌入式、人工智能等开发,专注于程序员成长的那点儿事,希望在成长的路上有你相伴!君志所向,一往无前!数组:C语言数据处理...
- ES6史上最全数JS数组方法合集-02-数组操作
-
数组生成array.ofletres=Array.of(1,2,3)console.log(res)//[1,2,3]下标定位indexOf用于查找数组中是否存在某个值,如果存...
- 前端性能拉胯?这 8 个 JavaScript 技巧让你的代码飞起来!
-
在前端开发的江湖里,JavaScript就是我们手中的“绝世宝剑”。但为啥别人用剑就能轻松斩敌,你的代码却总拖后腿,页面加载慢、交互卡顿?别着急!今天带来8个超实用的JavaScript实...
- 12种JavaScript中最常用的数组操作整理汇总
-
数组是最常见的数据结构之一,我们需要绝对自信地使用它。在这里,我将列出JavaScript中最重要的几个数组常用操作片段,包括数组长度、替换元素、去重以及许多其他内容。1、数组长度大多数人都知道可...
- 手把手教你在Webpack写一个Loader
-
前言有的时候,你可能在从零搭建Webpack项目很熟悉,配置过各种loader,面试官在Webpack方面问你,是否自己实现过一个loader?如果没有去了解过如果去实现,确实有点尴尬,其...
- const关键字到底该什么用?(可以用const关键字定义变量吗)
-
文|守望先生经授权转载自公众号编程珠玑(id:shouwangxiansheng)前言我们都知道使用const关键字限定一个变量为只读,但它是真正意义上的只读吗?实际中又该如何使用const关键字...
- “JavaScript变量声明三兄弟,你真的会用吗?
-
在JavaScript中,var、let和const是声明变量的关键字,它们在作用域、变量提升、重复声明和重新赋值等方面有显著区别。以下是它们的相同点和不同点,并通过代码示例详细说明。一、相同点声明变...
- ES6(二)let 和 const(es6 var let const区别)
-
let命令let和var差不多,只是限制了有效范围。先定义后使用不管是什么编程语言,不管语法是否允许,都要秉承先定义,然后再使用的习惯,这样不会出幺蛾子。以前JavaScript比较随意,...
- js 里面 let 和 const的区别(js中的let)
-
在JavaScript(包括Vue、Node.js、前端脚本等)中,const和let是用于声明变量的两种方式,它们的主要区别如下:constvslet的区别特性constlet是否...
- JDK21新特性:Sequenced Collections
-
SequencedCollectionsJDK21在JEP431提出了有序集合(SequencedCollections)。引入新的接口来表示有序集合。这样的集合都有一个明确的第一个元素、第二个...
- 动态编程基础——第 2 部分(动态编程是什么)
-
有两种方法可以使用动态规划来解决问题。在这篇文章中,我们将了解制表法。请参阅我的动态编程基础——第1部分了解记忆方法。记忆制表什么是动态规划?它是一种简单递归的优化技术。它大大减少了解决给定...
- Lambda 函数,你真的的了解吗(lambda函数用法)
-
什么是lambda函数lambda函数是一个匿名函数,这意味着与其他函数不同,它们没有名称。这是一个函数,它添加两个数字,写成一个命名函数,可以按其名称调用它们:defadd(x,y):...
- JavaScript 数组操作方法大全(js数组操作的常用方法有哪些)
-
数组操作是JavaScript中非常重要也非常常用的技巧。本文整理了常用的数组操作方法(包括ES6的map、forEach、every、some、filter、find、from、of等)...
- 系列专栏(六):解构赋值(解构赋值默认值)
-
ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...
- js列表遍历方法解读(js遍历链表)
-
JavaScript提供了多种遍历数组(或列表)的方法。以下是一些常用的方法及其解读:for循环:vararray=[1,2,3,4,5];for(vari=0;...
- 一周热门
- 最近发表
-
- C语言速成之数组:C语言数据处理的核心武器,你真的玩透了吗?
- ES6史上最全数JS数组方法合集-02-数组操作
- 前端性能拉胯?这 8 个 JavaScript 技巧让你的代码飞起来!
- 12种JavaScript中最常用的数组操作整理汇总
- 手把手教你在Webpack写一个Loader
- const关键字到底该什么用?(可以用const关键字定义变量吗)
- “JavaScript变量声明三兄弟,你真的会用吗?
- ES6(二)let 和 const(es6 var let const区别)
- js 里面 let 和 const的区别(js中的let)
- JDK21新特性:Sequenced Collections
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)