JavaScript学习-3——数组、函数、递归
本章目录
-----------①数组
-----------②函数
-----------③递归
一、数组
弱类型:任何类型数据,且没有强度限制;
强类型:同一类型的数据存储的集合(内存中连续存储),有长度限制。
①创建数组:
//创建新数组
var arr = new Array();
//创建新数组并赋值
var arr = new Array(1,2,3,4,5,6);
②获取,数组的值:
var arr = new Array(1,2,3,4,5,6);
//获取相应序列的值
arr[0];
//序列从0开始,最大为长度-1;
alert(arr[1]);
//获取到数组中序列为1的数据。
输出结果:

③向数组中添加数据:
var arr = new Array(1,2,3,4,5,6);
arr[6]=10; document.write(arr[6]);
输出:
var arr = new Array(1,2,3,4,5,6);
var d =20;
for(var i=0;i<arr.length;i++){
if(d==arr[i]){
break;
}
if(i==arr.length-1){
arr[i+1]=d;
document.write(arr[i+1]);
}
}
输出:20
④输出索引号
var arr = new Array(1,2,3,4,5,6);
for(var a in arr){
document.write(a);
}
输出结果:
二、函数
四要素:
返回类型、函数名、参数列表、函数体
强类型语言:
int NAME (参数列表) { 函数体 }
类型 函数名 参数列表 函数体
弱类型语言:
function NAME(参数列表) {函数体}
//该函数封装完成后不是运行,需要调用
Show(); //调用函数
function Show(){
alert("这是一个简单的函数!!")
}
带有参数的函数
//这里的a是一个形参,假的参数(代号)
function(a){
alert(a);
}
Show("这是一个实参"); //实参,有真正值得参数 function Header(a,b){
alert(a+","+b)
}
Header(a,b); //输出两个参数的值
//传两个参数
有返回值得函数
function Show(a,b){
return(a+b);
}
var s =Show(1,2);
alert(s); // 返回3,
三、递归
例题:桃子
有一只猴子,每天吃一半桃子,扔一个坏的,第六天还剩一个,问一开始多少桃子?
//前一天数量 = (当前数量+1)*2
var sl =1;
function Show(n){
//给予第六天的桃子数量,使其只要6则传回1sl
if(n==6){
return sl;
}
else{
sl = (Show(n+1)+1)*2;
//计算公式:昨天的=[(今天天数+1)+1]*2
}
return sl;
}
alert(Show(1));
例题:阶乘
<script>
var n =prompt("请输入:","");
function Show(n){
//我们知道当n!,n=1或0的的时候阶乘为1;
if(n<1){
return 1;
}
//n! = (n-1)*n
else{
return Show(n-1)*n;
}
}
alert(Show(n));
</script>
当输入6时获得的结果:
是正确的。
例题、一共10级楼梯,每次可以走一步或两步,求一共多少种走法。
<script>
//一共10级楼梯,每次可以走一步或两步,求一共多少种走法。
function Show(n){
//第一阶有一种方法
if(n==1){
return 1;
}
//第二阶有两种方法:1+1 2
else if(n==2){
return 2;
}
//当前阶 = 上一阶的方法 + 前一阶的方法
else{
return Show(n-1)+Show(n-2);
}
}
console.log(Show(10));
</script>
输出结果:
正确
JavaScript学习-3——数组、函数、递归的更多相关文章
- JavaScript学习03 JS函数
JavaScript学习03 JS函数 函数就是包裹在花括号中的代码块,前面使用了关键词function: function functionName() { 这里是要执行的代码 } 函数参数 函数的 ...
- javascript学习总结之函数
前言 在学习javascript函数的时候,有几个经常很容易混淆的方法,call,apply,bind,caller,callee,这些方法的使用,这些也可以说是会频繁使用的一些方法,在此通过查阅相关 ...
- javascript之Array()数组函数讲解
Array()是一个用来构建数组的内建构造器函数.数组主要由如下三种创建方式: array = new Array() array = new Array([size]) array = new Ar ...
- 廖雪峰 JavaScript 学习笔记(函数)
JavaScript中,定义函数的方式如下: function abs(x) { if (x >= 0) { return x; } else { return -x; } } 上述abs()函 ...
- 【JavaScript学习笔记】函数、数组、日期
一.函数 一个函数应该只返回一种类型的值. 函数中有一个默认的数组变量arguments,存储着传入函数的所有参数. 为了使用函数参数方便,建议给参数起个名字. function fun1(obj, ...
- javascript学习笔记--迭代函数
概要 这里的迭代函数指的是对数组对象的操作方法,js数组共有五个迭代函数:every.fifter.forEach.map.some. 1.every every方法,返回值为Boolean类型,tr ...
- 04 Javascript的数据类型 数组 函数
javascript:包含ECMAscript DOM BOM 描述了以下内容: 语法 类型 语句 关键字 保留字 运算符 对象 引入方式: <script> alert(123) < ...
- Javascript 学习之数组 Array
数组在Javascript中占有很重要的地位.任何控件开发离不开数组的使用. 构造函数 new Array( ) new Array(size) new Array(element0, element ...
- JavaScript学习03(函数)
函数 函数定义 JavaScript 函数是通过 function 关键词定义的. 声明定义 function functionName(parameters) { 要执行的代码 } 被声明的函数不会 ...
随机推荐
- cut语法2
linux每日一命令--cut--按文件大小排序 显示前100行 显示后五列 ll -Sh|head -n 100|cut -d ' ' -f 5- 一.基本语法cut是一个选取命令,以行为单位,用指 ...
- wpf 控件简单介绍
- Java学习笔记43(Spring的jdbc模板)
在之前的学习中,我们执行sql语句,需要频繁的开流,关流比较麻烦,为了更加的简化代码,我们使用Spring 的jdbc模板jdbcTemplate来简化我们的代码量:需要导入的包有: 我们在之前的dr ...
- tp5 base64 图片上传
/** * 保存图片 */ public function uploads($value='') { // $file = base64_decode(request()->file('imag ...
- node day2 vue read html
app.js var http = require("http"); var fs = require('fs'); var url = require('url'); http. ...
- 第二节《Git暂存区》
在上一节中我们的demo版本库经历了一次提交,我们可以使用git og --stat查看一下提交日志. [root@git demo]# git log --statcommit 986a1bd458 ...
- 二十一、springcloud(七)服务网关zuul
1.简介 Eureka用于服务的注册于发现,Feign支持服务的调用以及均衡负载,Hystrix处理服务的熔断防止故障扩散,Spring Cloud Config服务集群配置中心,在微服务架构中,后端 ...
- mysql插中文出现错误 "incorrect string value:\x.....
mysql字符集的问题: mysql的表格整理应该改为gbk_chinese_ci,每个需要汉字的字段属性的整理也改为gbk_chinese_ci,
- EF LIKE 查询
<!-- CSDL content --> <edmx:ConceptualModels> <Schema Namespace="Model" Ali ...
- Excel技巧--单列变多行
当上图的单列转变成多行时,可以这么做: 1.在第一行输入A2.A3,向右拖拉第一行: 2.第二行按第一行最右顺序,写下A12,再向右拖拉出第二行: 3.选择这两行,再拖拉出一串连续顺序的多行来: 4. ...