数组
定义和分类
-
定义:是按次序排列的一组数据集合
- 就是一个容器可以存储很多的值,任何类型的数据都可以存放
-
分类
1.索引数组
数组元素的下标是数值,这样的数组是索引数组
2、关联数组
数组元素的下标是字符串,这样的数组就是关联数组
print_r($_SERVER);
print_r($_SERVER['HTTP_HOST']);
//在字符串中 不需要加 引号
$h3 = "<h3>$_SERVER[HTTP_HOST]</h3>";
echo $h3;
创建
<?php
$v1 = array("cc","dd","ff");
$v2 = [];
var_dump($v1);
echo "<br>";
var_dump($v2);
//添加数据
echo "<br>";
?>
- 关于key
- key没有自定义,默认是从0开始,向后递增
- 数组中的key可以任意指定,可以是不连续的,但是必须是
唯一
的 - key可以是数字和字符串,其他的不可以。
<?php
$newList = array(
1 => "CC",
2 => "tt",
3 =>"hh",
10 =>"dd",
"t" => "gg"
);
var_dump($newList);
//注意:数组中的key不一定是 1,2,3,你可以设置任意你想要的key对应value
?>
-
曾-删-改
<?php
$newList = array();
//没有指定key
$newList[] = "添加的新元素";
//指定key
$newList[3] = "添加的000";
echo "<br>";
print_r($newList);
//修改
$newList[0] = "哈哈哈你是一个boby";
echo "<br>";
print_r($newList);
//删除
unset($newList[0]);
echo "<br>";
print_r($newList);
?>
-
遍历
foreach (数组 as 对应的key => 对应的value) { # code... }
直接输入value
foreach (数组 as 对应的value) { # code... }
<?php
$arr1 = array("name"=>"cc","age"=>"18","height"=>"1.70");
foreach ($arr1 as $value){
echo "值是:".$value;
echo "</br>";
};
echo "</br>";
foreach ($arr1 as $key => $value){
echo "key是:".$key."值是:".$value;
echo "</br>";
};
?>
二维数组
<?php
$data = array(11,12,13,14,15);
$array = array($data,$data);
print_r($array);
?>
数组中常用的函数
-
数组的长度
count(数组)
-
获取数组的key和value
- 获取key是
array_keys()
- 获取values是
array_values()
- 获取key是
<?php
$data = array(
"one" => "10",
"two" => "20",
"three" =>"30"
);
echo "<br>";
//获取keys
print_r(array_keys($data));
//获取values
echo "<br>";
print_r(array_values($data));
//结果:
Array ( [0] => one [1] => two [2] => three )
Array ( [0] => 10 [1] => 20 [2] => 30 )
?>
-
判断key或者value是否存在,返回的是bool
array_key_exists($key,$array )
in_array($value,$array)
<?php
$data = array(
"one" => "10",
"two" => "20",
"three" =>"30"
);
//判断摸个键值是否存在
echo "<br>,判断键值是否存在==========,<br>";
echo array_key_exists("one",$data);
echo "<br>,判断键值是否存在==========,<br>";
echo in_array("20",$data);
打印结果:1
?>
-
数组的合并
array_merge($array,$array2)
<?php
$data = array(
"one" => "10",
"two" => "20",
"three" =>"30"
);
//数组合并
$array = [
"a" => "100",
"b" =>"200"
];
print_r(array_merge($data,$array)) ;
//结果:
Array (
[one] => 10
[two] => 20
[three] => 30
[a] => 100
[b] => 200
)
?>
-
数组排序
-
sort($array)
升序排序 -
rsort($array)
降序排序
-
$array = [
"a" => "100",
"d" =>"2",
"h" =>"45",
"m"=>"30",
"b" =>"200"
];
echo "<br>";
echo "数组排序升序";
sort($array);
print_r($array);
echo "<br>";
echo "数组排序降序";
rsort($array);
print_r($array);
- 保持下标不变,按结果排序
asort($array)
升序 - 保持下标不变,按结果排序
arsort($array)
降序
<?php
$array = [
"a" => "100",
"d" =>"2",
"h" =>"45",
"m"=>"30",
"b" =>"200"
];
echo "<br>";
echo "数组排序下标不变,升序";
asort($array);
print_r($array);
echo "<br>";
echo "数组排序下标不变 降序";
arsort($array);
print_r($array);
?>
-
数组的常用函数 添加-删除
- array_shift() - 将数组开头的单元移出数组
- array_push() - 将一个或多个单元压入数组的末尾(入栈)
- array_pop() - 弹出数组最后一个单元(出栈)
- array_unshift() - 在数组开头插入一个或多个单元
-
array_search()
返回数组的下标
-
数组的常用的算法
-
冒泡排序
- 原理
- 由下标 i 逐次和 i+1 比较
- 2个数比较一次,3个数比较2次,数组内的元素比较是
length-1
次,既是比较的轮数 - 比较一轮之后,确定的是最大值,由于确定了最大值,那么无需在和最大的比较,只需要比较
length-1-1
次 就是比较的次数
-
<?php
$array = [2,30,23,45,90,1,5,28];
$num = count($array);
//外层比较轮数
for ($i = 0; $i < $num - 1; $i++) {
//内层比较次数
for ($j=0; $j <$num - 1 - $i ; $j++) {
if ($array[$j] > $array[$j + 1]) {
$temp = $array[$j];
$array[$j] = $array[$j + 1];
$array[$j + 1] = $temp;
}
}
}
//结果
Array (
[0] => 1
[1] => 2
[2] => 5
[3] => 23
[4] => 28
[5] => 30
[6] => 45
[7] => 90
)
?>
-
查入排序
<?php
//插入排序
$arr = [30,50,10,1,32];
$num = count($arr);
for ($j=1; $j < $num; $j++) {
$target = $arr[$j];
for ($i= $j - 1; $i >= 0; $i--) {
if ($arr[$i] > $arr[$i + 1]) {
$arr[$i + 1] = $arr[$i];
$arr[$i] = $target;
}
}
}
echo "<br>,排序";
print_r($arr);
?>
-
二分查找法
- 数组是有序的并且不能有重复的元素
- 原理:找到下标
中间数
,根据目标值
和下标中间数对应的值
比较,循环查找,循环比较。查出对象的目标值的下标
<?php
$arr2 = [3,4,5,8,15,20,25,30,58,90];
$num = count($arr2) - 1;
$l = 0;
$search = 90;
while ($l <= $num) {
$p = ($l + $num)/2;
$m = ceil($p);
if ($arr2[$m] == $search) {
echo $m;
break;
} else if($search > $arr2[$m]){
$l = $m + 1;
}else {
$num = $m - 1;
}
}
?>