首页 > 编程语言 > 详细

php-数组

时间:2019-09-23 16:41:41      阅读:93      评论:0      收藏:0      [点我收藏+]

数组基础

php中,数组的下标可以是整数,或字符串。

php中,数组的元素顺序不是由下标决定,而是由其“加入”的顺序决定。 

定义:
$arr1 = array(元素1,元素2,。。。。。 );

array(1,  5,  1.1,  “abc”,  true,  false); //可以存储任何数据,此时为“默认下标”,

array(2=>1,  5=>5,  3=>1.1,  7=>“abc”,  0=>true);//下标可以任意设定(无需顺序,无需连续)

array(2=>1,  5,  1=>1.1,  “abc”,  0=>true)//可以加下标,也可以不加(默认下标),下标分别是:2,3,1,4,0

//默认下标规则:前面已经用过的最大数字下标+1

array(2=>1,  ‘dd’=>5,  1=>1.1,  “abc”,  0=>true)//混合下标,同样遵循默认下标规则

array(-2=>1,  ‘dd’=>5,  1.1,  “abc”,  true); //负数下标不算在整数下标中,而只当作字符下标

//则最好3项的下标是:0, 1, 2

array(2.7=>1,  ‘dd’=>5,  1=>1.1,  “abc”,  0=>true)//浮点数下标为自动转换为整数,且直接抹掉小数

array(“2.7” =>1,  ‘dd’=>5,  “11”=>1.1,  “abc”,  true)//纯数字字符串下标,当作数字看待,

//则此时下标为:2, ‘dd’, 11, 12, 13

array(2=>1,  ‘dd’=>5,  true=>1.1,  “abc”,  false=>true)//布尔值当下标,则true1false0

array(2=>1,  ‘dd’=>5,  2=>1.1,  “abc”,  true)//如果下标跟前面的重复,则单纯覆盖前面同名下标的值

//此时相当于为:array(2=>1.1,  ‘dd’=>5,  “abc”,  true)

其他形式;

$arr1[] = 1;

$arr1[] = 5;

$arr1[] = 1.1; //直接在变量后面使用[],就成为数组,并依次赋值。

。。。。

$arr2[‘aa’] = 1;

$arr2[‘bbbcc’] = 5;

$arrr2[5] = 1.1;

。。。。。。。。

这种形式写的下标,其实跟使用array语法结构几乎一样

取值:通过下标。

 

数组的分类

从键值关系:

关联数组:通常是指下标为字符串,并且该字符串大体可以表达出数据的含义的数组。

例:$person = array(

“name” => “小花”,  

“age”=>18,

“edu” => “大学毕业” 

);

索引数组:

通常是指一个数组的下标是严格的从0开始的连续的数字下标——跟js数组一样。

 

从数组层次来分:

一维数组:

就是一个数组中的每一个元素值,都是一个普通值(非数组值)

$arr1 = array(

“name” => “小花”,  

“age”=>18,

“edu” => “大学毕业” 

);

 

二维数组:

一个数组中的每一项,又是一个一维数组。

$arr1 = array(

“name” => array(‘小花’,     ‘小芳’,   ‘小明’, );  

“age”=> array(18,      22,       19),

“edu” => array(“大学毕业”,  ‘中学’,    ‘小学’)

);

 

多维数组:

依此类推。。。

 

多维数组的一般语法形式:

$v1 = 数组名[下标][下标][.....]

 

数组遍历

遍历基本语法

foreach( $arr   as   [ $key  => ] $value ) //$key可以称为键变量,$value可以称为值变量。

{

//这里就可以对$key  $value 进行所有可能的操作——因为他们就是一个变量

//$key 代表每次取得元素的下标,可能是数字,也可以能是字符串

//$value 代表每次取得元素的值,可能是各种类型。

//此循环结构会从数组的第一项一直遍历循环到最后一项,然后结束。

}

 

交换原理:

 

数组指针和遍历原理

每个数组,其内部都有一个“指针”,该指针决定了该数组当前取值的时候,取到的元素。

foreach遍历过程中,都是依赖与该指针而进行的!

 

举例:$arr1 = array(2=>1,  ‘dd’=>5,  1=>1.1,  “abc”,  0=>true)

 

 

下标:

2

‘dd’

1

3

0

值:

1

5

1.1

‘abc’

true

 

指针除了负责foreach循环的位置设定之外,还有其他一些函数也依赖于该指针:

1$v1 = current( $arr1); //取得$arr1中当前指针所指向的元素的值,如果没有指向元素,则为false

2$v1 = key$arr1); //取得$arr1中当前指针所指向的元素的下标,。。。。。false

3$v1 = next($arr1 ) //将指针移向“下一个元素”,然后取得该下一个元素的值;

4$v1 = prev($arr1) //将指针移向“上一个元素”,然后取得该上一个元素的值

5$v1 = reset($arr1); //将指针移向“第一个元素”,然后取得该元素的值——数组指针初始化

6$v1 = end($arr1); //将指针移向“最后一个元素”,然后取得该元素的值

7$v1 = each($arr1) //取得当前元素的下标和值,然后移动指针到下一个位置。

 

数组遍历的流程图:

 

 

 

for+next+reset遍历数组

reset( $arr1 ); //重置数组,即:数组指针初始化,这里,返回的数据被“丢弃”了。

$len = count( $arr1);

for$i = 0;  $i < $len  $i++){

$key = key ($arr1 ); //下标

$value = current( $arr1 ); //

//然后这里就可以对$key $value进行任何作为变量的操作

next($arr1);//这里,移动指针到下一个元素(也同时丢弃了返回值)

}

 

 

while+each()+list()遍历数组

each()函数解释:

each()函数可以取得一个数组中的一个元素的下标和值,然后再放入一个新的数组中,并且指针后移一位。

该新的数组,有4个元素,但存储的是下标和值的“双份”,类似下述形式:

array(

1 => 取出来的值,

‘value’ = >取出来的值,

0 = > 取出来的下标(键名),

‘key’ => 取出来的下标(键名)

);

 

 

list()函数解释:

使用形式:

list($v1, $v2, $v3,$v4 .... = 数组$arr1;

其作用是:依次取得数组$arr1中下标为0123, ....的元素的值,并一次性放入多个变量中(一一对应)

即其相当于如下语句:

$v1 = $arr1[0];

$v2 = $arr1[1];

$v3 = $arr1[2];

$v4 = $arr1[3];

..........

但是注意:只能实现这样的“从0开始的连续数字下标的元素的取值”(但并非要求数组的元素的顺序为同样的数字顺序)

 

 

然后开始使用这2个函数和while循环结构来实现数组遍历:

形式:

reset($arr1);

 while ( list ($key, $value ) = each( $arr1) ) //从数组$arr1中一次次取出元素,

//each到数组最后的时候,就返回false,即此时循环结束

{

//这里,就可以对$key ,$value进行操作了。

}

foreach 遍历细节探讨

foreach也是正常的循环语法结构,可以有break和continue等操作。

遍历过程中值变量默认的传值方式是值传递。

遍历过程中值变量可以人为设定为引用传递

foreach($arr as $key => &$value){ ... }

键变量不可以设定为引用传递

 

foreach默认是原数组上进行遍历。但如果在遍历过程中对数组进行了某种修改或某种指针性操作(就是指前面的指针函数),则会复制数组后在复制的数组上继续遍历循环。

 

foreach中如果值变量是引用传递,则无论如何都是在原数组上进行。

数组排序思想介绍

参考:

http://zh.wikipedia.org/wiki/冒泡排序

冒泡排序

目标:将下列数组进行正序(从小到大)排列出来

$arr2 = array( 5,  15,  3,  4911);

一般性逻辑描述:

1,对该数组从第一个元素开始,从左到右,相邻的2个元素比较大小:如果左边的比右边的大,则将他们俩交换位置,结果:

array( 5,  15,  3,  4911);(原始)

array( 5,  15,  3,  4911);

 array( 5,  315,  4911);

array( 5,  34,  15 911);

array( 5,  34,  915 11);

array( 5,  34,  91115);

此时,才“走完一轮回”,继续下一轮:

array( 5,  34,  91115);(初始)

array( 3  5 4,  91115);

array( 3  45  91115);

array( 3  45  9 1115);

array( 3  45  911 15);

继续下一轮:

array( 3  45  911 15);

。。。。。。。。

最初:

5

15

3

4

9

11

1趟之后:

5

3

4

9

11

15

2趟之后

3

4

5

9

11

15

3趟之后

3

4

5

9

11

15

4趟之后

3

4

5

9

11

15

5趟之后

3

4

5

9

11

15

 

隐含的逻辑描述(假设数组有n项):

1, 需要进行n-1趟的“冒泡”比较过程。

2, 每一趟的比较都前一趟少比一次,第一趟需要比较n-1

3, 每趟比较,都是从数组的开头(0)开始,跟紧挨的元素比较,并进行交换(需要的时候)

 

 

选择排序

目标:将下列数组进行正序(从小到大)排列出来

$arr2 = array( 5,  15,  3,  4911);

一般性逻辑描述:

1趟:取得该数组中的最大值及其下标,然后跟该数组的最后一项“交换”(倒数第1项确定)

2趟:取得该数组中除最后1项中的最大值及其下标,然后跟倒数第2项交换(倒数第2项确定)

3趟:取得该数组中除最后2项中的最大值及其下标,然后跟倒数第3项交换(倒数第3项确定)

。。。。。。

最初:

5

15

3

4

9

11

1趟之后:

5

11

3

4

9

15

2趟之后

5

9

3

4

11

15

3趟之后

5

4

3

9

11

15

4趟之后

3

4

5

9

11

15

5趟之后

3

4

5

9

11

15

隐含的逻辑描述(假设数组有n项):

1,要进行n-1趟才可能得出结论

2,每一趟要找的数据的个数都比前一趟少一个,第1趟要找n

3,每次找出的最大值所在的项,和要与之进行交换的项的位置,依次减1,第一次的位置n-1

 

php-数组

原文:https://www.cnblogs.com/caoqh/p/11572265.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!