一、数组的分类
1、关联数组:通常是指下标为字符串,并且该字符串大体可以表达出数据的含义的数组。
2、索引数组:通常是指一个数组的下标是严格的从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)
指针除了负责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中下标为0,1,2,3, ....的元素的值,并一次性放入多个变量中(一一对应)
即其相当于如下语句:
··$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等操作。
遍历过程中值变量默认的传值方式是值传递。
遍历过程中值变量可以人为设定为引用传递:
oforeach($arr as $key => &$value){ ... }
键变量不可以设定为引用传递
foreach默认是原数组上进行遍历。但如果在遍历过程中对数组进行了某种修改或某种指针性操作(就是指前面的指针函数),则会复制数组后在复制的数组上继续遍历循环。
冒泡排序:
目标:将下列数组进行正序(从小到大)排列出来
$arr2 = array( 5, 15, 3, 4, 9, 11);
一般性逻辑描述:
1,对该数组从第一个元素开始,从左到右,相邻的2个元素比较大小:如果左边的比右边的大,则将他们俩交换位置,结果:
array( 5, 15, 3, 4, 9, 11);(原始)
array( 5, 15, 3, 4, 9, 11);
array( 5, 3, 15, 4, 9, 11);
array( 5, 3, 4, 15, 9, 11);
array( 5, 3, 4, 9, 15, 11);
array( 5, 3, 4, 9, 11, 15);
此时,才“走完一轮回”,继续下一轮:
array( 5, 3, 4, 9, 11, 15);(初始)
array( 3 5, 4, 9, 11, 15);
array( 3 4, 5 9, 11, 15);
array( 3 4, 5 9, 11, 15);
array( 3 4, 5 9, 11, 15);
继续下一轮:
array( 3 4, 5 9, 11, 15);
隐含的逻辑描述(假设数组有n项):
1, 需要进行n-1趟的“冒泡”比较过程。
2, 每一趟的比较都前一趟少比一次,第一趟需要比较n-1次
3, 每趟比较,都是从数组的开头(0)开始,跟紧挨的元素比较,并进行交换(需要的时候)
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>冒泡排序</title> 6 </head> 7 8 <body> 9 <?php 10 $arr2 = array(5,15,3,4,9,11); 11 $len = count($arr2); //count()函数用来统计数组元素个数,count()函数格式是count($array,mode),mode为可选参数 12 // 需要进行n-1趟的冒泡比较 13 echo "<br/>排序之前:"; 14 var_dump($arr2); //print_r通常用于打印变量的相关信息,通常在调试中使用。 15 for($i=0;$i<$len-1;$i++){ 16 for($k=0;$k<$len-1-$i;$k++){ 17 if($arr2[$k]>$arr2[$k+1]){ 18 $temp=$arr2[$k]; 19 $arr2[$k] = $arr2[$k+1]; 20 $arr2[$k+1]=$temp; 21 } 22 } 23 } 24 echo "<br/>排序之后:"; 25 var_dump($arr2); 26 ?> 27 </body> 28 </html>
效果图:
选择排序
目标:将下列数组进行正序(从小到大)排列出来
$arr2 = array( 5, 15, 3, 4, 9, 11);
一般性逻辑描述:
第1趟:取得该数组中的最大值及其下标,然后跟该数组的最后一项“交换”(倒数第1项确定)
第2趟:取得该数组中除最后1项中的最大值及其下标,然后跟倒数第2项交换(倒数第2项确定)
第3趟:取得该数组中除最后2项中的最大值及其下标,然后跟倒数第3项交换(倒数第3项确定)
隐含的逻辑描述(假设数组有n项):
1,要进行n-1趟才可能得出结论
2,每一趟要找的数据的个数都比前一趟少一个,第1趟要找n个
3,每次找出的最大值所在的项,和要与之进行交换的项的位置,依次减1,第一次的位置n-1