数组

PHP.jpg

数组

定义和分类
  • 定义:是按次序排列的一组数据集合
    • 就是一个容器可以存储很多的值,任何类型的数据都可以存放
  • 分类

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>";
?>
image.png
  • 关于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
?>
image.png
  • 曾-删-改
<?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);

?>
image.png
  • 遍历

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>";
};

?>
image.png

二维数组

<?php
$data = array(11,12,13,14,15);

$array = array($data,$data);
print_r($array);
?>
image.png

数组中常用的函数

  • 数组的长度count(数组)
  • 获取数组的key和value
    • 获取key是array_keys()
    • 获取values是array_values()
<?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);

image.png
  • 保持下标不变,按结果排序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);
?>
image.png
  • 数组的常用函数 添加-删除
    • array_shift() - 将数组开头的单元移出数组
    • array_push() - 将一个或多个单元压入数组的末尾(入栈)
    • array_pop() - 弹出数组最后一个单元(出栈)
    • array_unshift() - 在数组开头插入一个或多个单元
    • array_search() 返回数组的下标
  • 数组的常用的算法

    • 冒泡排序
      • 原理
      • 由下标 i 逐次和 i+1 比较
      • 2个数比较一次,3个数比较2次,数组内的元素比较是length-1次,既是比较的轮数
      • 比较一轮之后,确定的是最大值,由于确定了最大值,那么无需在和最大的比较,只需要比较 length-1-1次 就是比较的次数
        image.png
<?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;
    }
}

?>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、数组定义 array() 1、索引数组 在一个变量中,存储一个或多个值。数组中的每一个元素都有一个访问ID,根...
    竹与豆阅读 551评论 0 0
  • 第三章 数组 数组是一个可以存储一组或一系列数值的变量 一个包含其他数组的数组称为多维数组。 关联数组允许使用更...
    梁烨端木阅读 752评论 0 0
  • PHP数组函数,摘录于PHP手册 1、array_change_key_case (PHP 4 >= 4.2.0,...
    kotlin360阅读 747评论 2 1
  • Javascript有很多数组的方法,有的人有W3C的API,还可以去MDN上去找,但是我觉得API上说的不全,M...
    顽皮的雪狐七七阅读 4,292评论 0 6
  • 原创声明 本文系作者辛苦码字所得,欢迎分享和转载,但请在明显位置注明作者的如下信息:笔名:来碗鸡蛋面简书主页:ht...
    来碗鸡蛋面阅读 3,255评论 0 4