本章目录

-----------①数组

-----------②函数

-----------③递归

一、数组

弱类型:任何类型数据,且没有强度限制;

强类型:同一类型的数据存储的集合(内存中连续存储),有长度限制。

①创建数组:

//创建新数组
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——数组、函数、递归的更多相关文章

  1. JavaScript学习03 JS函数

    JavaScript学习03 JS函数 函数就是包裹在花括号中的代码块,前面使用了关键词function: function functionName() { 这里是要执行的代码 } 函数参数 函数的 ...

  2. javascript学习总结之函数

    前言 在学习javascript函数的时候,有几个经常很容易混淆的方法,call,apply,bind,caller,callee,这些方法的使用,这些也可以说是会频繁使用的一些方法,在此通过查阅相关 ...

  3. javascript之Array()数组函数讲解

    Array()是一个用来构建数组的内建构造器函数.数组主要由如下三种创建方式: array = new Array() array = new Array([size]) array = new Ar ...

  4. 廖雪峰 JavaScript 学习笔记(函数)

    JavaScript中,定义函数的方式如下: function abs(x) { if (x >= 0) { return x; } else { return -x; } } 上述abs()函 ...

  5. 【JavaScript学习笔记】函数、数组、日期

    一.函数 一个函数应该只返回一种类型的值. 函数中有一个默认的数组变量arguments,存储着传入函数的所有参数. 为了使用函数参数方便,建议给参数起个名字. function fun1(obj, ...

  6. javascript学习笔记--迭代函数

    概要 这里的迭代函数指的是对数组对象的操作方法,js数组共有五个迭代函数:every.fifter.forEach.map.some. 1.every every方法,返回值为Boolean类型,tr ...

  7. 04 Javascript的数据类型 数组 函数

    javascript:包含ECMAscript DOM BOM 描述了以下内容: 语法 类型 语句 关键字 保留字 运算符 对象 引入方式: <script> alert(123) < ...

  8. Javascript 学习之数组 Array

    数组在Javascript中占有很重要的地位.任何控件开发离不开数组的使用. 构造函数 new Array( ) new Array(size) new Array(element0, element ...

  9. JavaScript学习03(函数)

    函数 函数定义 JavaScript 函数是通过 function 关键词定义的. 声明定义 function functionName(parameters) { 要执行的代码 } 被声明的函数不会 ...

随机推荐

  1. nginx——控制 Nginx 并发连接数

    1. 限制单个 IP 的并发连接数 .... http { include mime.types; default_type application/octet-stream; sendfile on ...

  2. 解决VS2010使用mscomm控件无法接收数据的问题【转】

    之前有用过VC6的mscomm控件.所以这次也想继续用此控件实现此功能,结果没想到刚一上手还真的绕了不少弯子.主要是因为VC2010下对mscomm控件的添加,以及对控件成员变量的添加有点小繁琐,特此 ...

  3. .NET并行计算和并发5:多线程编程一般指导性原则

    使用多线程时要考虑以下准则: 不要使用 Thread.Abort 终止其他线程. 对另一个线程调用 Abort 无异于引发该线程的异常,也不知道该线程已处理到哪个位置. 不要使用 Thread.Sus ...

  4. dos脚本2

    一.简单批处理内部命令简介  1.Echo 命令  打开回显或关闭请求回显功能,或显示消息.如果没有任何参数,echo 命令将显示当 前回显设置.  语法  echo [{on off}] [mess ...

  5. 关于第一次在IED(MyEclipse)部署Maven时,pom.xml头部报这样的错---org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project.MavenProject, org.apache.maven.archiver.MavenArchiveConfiguration)

    rg.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project.MavenProject, org.apache ...

  6. 著名的Log4j是怎么来的?

    Java在设计之初,借鉴了很多其他语言不错的特性和优点,唯独没有设计日志系统,但是日志的重要性不言而喻,一旦程序运行起来,运行结果与预期不一致,基本就是出Bug了,这个时候需要进行Bug排查,一般有两 ...

  7. sklearn.model_selection.StratifiedShuffleSplit

    sklearn.model_selection.StratifiedShuffleSplit

  8. jsonify

    在flask中通过响应,将json数据显示在网页中,并且将Content-Type该为application/json格式 1,第一种方法: from flask import jsonify @ap ...

  9. confluence中org.apache.tomcat.util.net.NioEndpoint$Acceptor.run Socket accept failed的解决方法

    https://www.cnblogs.com/heyongboke/p/9806396.html 1.confluence中报错信息如下: 严重 [http-nio-18090-Acceptor-0 ...

  10. Xamarin SearchView 用法摘记

    与Windows开发不同,这个控件的事件比较难找,费了半天劲才知道应该用哪个事件.核心代码如下: public class MainActivity : Activity { protected ov ...