当前位置: 首页 > news >正文

PHP 数组与数据结构详解


PHP 学习资料

PHP 学习资料

PHP 学习资料


在 PHP 编程中,数组是一种非常重要的数据类型,它能够存储多个值,并且可以方便地进行各种操作。同时,了解常见的数据结构实现,对于优化程序性能和解决复杂问题也至关重要。接下来,我们将深入探讨 PHP 中数组的创建、遍历、排序、合并等操作,以及一些常见的数据结构实现。

一、数组的创建

1. 使用 array () 函数创建数组

这是最常用的方式,array() 实际上是一种结构,并非严格意义上的函数。可以创建包含不同类型元素的数组,索引可以是整数或字符串。

// 索引数组,存储整数
$numbers = array(1, 3, 5, 7, 9);
// 索引数组,存储字符串
$colors = array("red", "blue", "green");
// 关联数组,键名为字符串,键值为不同类型数据
$student = array("name" => "张三", "age" => 17);
// 空数组
$emptyArray = array();

2. 使用 compact () 函数创建数组

compact() 函数可以将一个或多个变量转换为数组。

$firstname = "Peter";
$lastname = "Griffin";
$age = 38;
$result = compact("firstname", "lastname", "age");
print_r($result);

上述代码会输出一个包含 firstname、lastname 和 age 对应值的数组。

3. 使用 array_combine () 函数创建数组

array_combine() 函数将两个数组合并成一个新数组,其中一个数组的元素作为键名,另一个数组的对应元素作为键值。

$keys = array("a", "b", "c", "d");
$values = array("Cat", "Dog", "Horse", "Cow");
$newArray = array_combine($keys, $values);
print_r($newArray);

需注意,两个参数数组必须有相同数目的元素。

4. 使用 range () 函数创建数组

range() 函数用于创建一个包含指定范围元素的数组,可以是整数范围或字符范围。

// 创建包含0到5的整数数组
$numberRange = range(0, 5);
print_r($numberRange);
// 创建包含0到50,步长为10的整数数组
$numberRangeStep = range(0, 50, 10);
print_r($numberRangeStep);
// 创建包含'a'到'd'的字符数组
$letterRange = range("a", "d");
print_r($letterRange);

5. 使用 array_fill () 函数创建数组

array_fill() 函数用给定的值填充数组。

// 从索引2开始,创建包含3个值为"Dog"的数组
$filledArray = array_fill(2, 3, "Dog");
print_r($filledArray);

二、数组的遍历

1. foreach 循环

这是最常用的遍历数组方式,可方便地访问数组中的每个元素及其键(如果是关联数组)。

$students = array("张三" => 18, "李四" => 20, "王五" => 22);
foreach ($students as $name => $age) {
    echo "$name 的年龄是 $age 岁。<br>";
}

2. for 循环

适用于索引数组,通过数字索引来访问数组元素。

$numbers = array(10, 20, 30, 40, 50);
$count = count($numbers);
for ($i = 0; $i < $count; $i++) {
    echo $numbers[$i]. "<br>";
}

3. while 循环

结合 each() 函数(php7.2 版本之后已废弃)或其他方式来遍历数组。在 php7.2 之前版本可使用如下方式:

$numbers = array(10, 20, 30, 40, 50);
reset($numbers);
while (list($key, $value) = each($numbers)) {
    echo "键:$key,值:$value<br>";
}

在高版本中,可以使用 current()、key() 和 next() 函数组合实现类似功能:

$numbers = array(10, 20, 30, 40, 50);
while ($value = current($numbers)) {
    $key = key($numbers);
    echo "键:$key,值:$value<br>";
    next($numbers);
}

4. array_walk () 函数

使用回调函数对数组的每个元素进行操作。

function square(&$value, $key) {
    $value = $value * $value;
}
$numbers = array(2, 3, 4, 5);
array_walk($numbers, "square");
print_r($numbers);

5. array_map () 函数

将回调函数应用于数组的每个元素,并返回一个包含操作结果的新数组。

function cube($value) {
    return $value * $value * $value;
}
$numbers = array(2, 3, 4, 5);
$newNumbers = array_map("cube", $numbers);
print_r($newNumbers);

三、数组的排序

1. 升序和降序排序

sort() 函数:对数组进行升序排序,索引会重新排列。

$arr = array(3, 1, 2, 5, 4);
sort($arr);
print_r($arr);

rsort() 函数:对数组进行降序排序,索引重新排列。

$arr = array(3, 1, 2, 5, 4);
rsort($arr);
print_r($arr);

2. 保留键值关系的排序

asort() 函数:对数组进行升序排序,同时保留键值关系。

$arr = array("a" => 3, "b" => 1, "c" => 2, "d" => 5, "e" => 4);
asort($arr);
print_r($arr);

arsort() 函数:对数组进行降序排序,保留键值关系。

$arr = array("a" => 3, "b" => 1, "c" => 2, "d" => 5, "e" => 4);
arsort($arr);
print_r($arr);

3. 按键名排序

ksort() 函数:对数组按键名进行升序排序。

$arr = array("b" => 1, "c" => 2, "a" => 3);
ksort($arr);
print_r($arr);

krsort() 函数:对数组按键名进行降序排序。

$arr = array("b" => 1, "c" => 2, "a" => 3);
krsort($arr);
print_r($arr);

4. 用户自定义比较函数排序

usort() 函数:对数组使用用户自定义的比较函数进行排序。

$students = array(
    array("name" => "Tom", "age" => 20),
    array("name" => "Bob", "age" => 23),
    array("name" => "Jerry", "age" => 18)
);
function cmp($a, $b) {
    return $a["age"] - $b["age"];
}
usort($students, "cmp");
print_r($students);

uasort() 函数:使用用户自定义的比较函数进行排序,并保留键值关系。

function cmp1($a, $b) {
    return $a["age"] > $b["age"]? -1 : 1;
}
uasort($students, "cmp1");
print_r($students);

uksort() 函数:使用用户自定义的比较函数按键名进行排序。

function cmp2($a, $b) {
    return strcmp($a["name"], $b["name"]);
}
uksort($students, "cmp2");
print_r($students);

四、数组的合并

1. 使用 + 运算符

可以将两个数组合并,当有相同键名时,左边数组的元素会保留,右边数组相同键名的元素会被忽略。

$array1 = array("a" => 1, "b" => 2);
$array2 = array("b" => 3, "c" => 4);
$mergedArray = $array1 + $array2;
print_r($mergedArray);

2. 使用 array_merge () 函数

array_merge() 函数也用于数组合并。对于索引数组,它会将所有元素按顺序合并;对于关联数组,如果有相同键名,后面数组的元素会覆盖前面数组的元素。

$array1 = array("a" => 1, "b" => 2);
$array2 = array("b" => 3, "c" => 4);
$mergedArray = array_merge($array1, $array2);
print_r($mergedArray);
// 索引数组合并
$array3 = array(1, 2, 3);
$array4 = array(4, 5, 6);
$mergedArray2 = array_merge($array3, $array4);
print_r($mergedArray2);

五、常见的数据结构实现

1. 栈(Stack)

栈是一种后进先出(LIFO)的数据结构。在 PHP 中,可以使用数组来简单实现栈的功能。

// 初始化栈
$stack = array();
// 入栈操作
array_push($stack, "apple");
array_push($stack, "banana");
array_push($stack, "cherry");
// 出栈操作
$topElement = array_pop($stack);
echo "弹出的元素: ". $topElement. "<br>";
print_r($stack);

2. 队列(Queue)

队列是一种先进先出(FIFO)的数据结构。同样可以用数组实现。

// 初始化队列
$queue = array();
// 入队操作
array_push($queue, "apple");
array_push($queue, "banana");
array_push($queue, "cherry");
// 出队操作
$frontElement = array_shift($queue);
echo "取出的元素: ". $frontElement. "<br>";
print_r($queue);

3. 链表(Linked List)

链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。在 PHP 中,可以通过类来实现链表。

class Node {
    public $data;
    public $next;
    public function __construct($data) {
        $this->data = $data;
        $this->next = null;
    }
}

class LinkedList {
    private $head;
    public function __construct() {
        $this->head = null;
    }

    // 添加节点到链表尾部
    public function add($data) {
        $newNode = new Node($data);
        if ($this->head == null) {
            $this->head = $newNode;
        } else {
            $current = $this->head;
            while ($current->next!= null) {
                $current = $current->next;
            }
            $current->next = $newNode;
        }
    }

    // 遍历链表
    public function traverse() {
        $current = $this->head;
        while ($current!= null) {
            echo $current->data. " ";
            $current = $current->next;
        }
        echo "<br>";
    }
}

$linkedList = new LinkedList();
$linkedList->add("apple");
$linkedList->add("banana");
$linkedList->add("cherry");
$linkedList->traverse();

掌握 PHP 中数组的各种操作以及常见数据结构的实现,对于编写高效、灵活的 PHP 程序至关重要。无论是简单的数据存储和处理,还是复杂的算法实现,这些知识都能为开发者提供有力的支持 。在实际开发中,应根据具体需求选择合适的数组操作和数据结构,以优化程序性能和代码的可读性。

相关文章:

  • 【NLP 22、语言模型 language model】
  • Kotlin 扩展
  • 排序与查找算法(C语言实现)
  • 【Linux开发工具】调试器-gdb
  • 【动态路由】系统Web URL资源整合系列(后端技术实现)【nodejs实现】
  • 代码随想录算法【Day46】
  • PHP处理大文件上传
  • 搜广推校招面经十六
  • es和kibana安装
  • WEB安全--SQL注入--堆叠注入
  • 53倍性能提升!TiDB 全局索引如何优化分区表查询?
  • 关系数据库标准语言SQL
  • SQL语句语法
  • 【Java】xxl-job
  • print(f“Random number below 100: {random_number}“)的其他写法
  • 【Linux】:网络协议
  • c++--变量内存分配
  • C语言进阶习题【3】5 枚举——找单身狗2
  • Pytest快速入门
  • 【MySQL】第五弹---数据类型全解析:从基础到高级应用
  • 浙江一家长称小学老师打孩子还威胁要从3楼扔下,当地警方已立案
  • 新城市志|GDP万亿城市,一季度如何挑大梁
  • 穆迪下调美国主权信用评级
  • 上海国际珠宝时尚功能区未来三年如何建设?六大行动将开展
  • 我国城市规划“全面体检”套餐出台,城市体检将逐步与供地计划等挂钩
  • 央视起底“字画竞拍”网络传销案:涉案44亿元,受害者众多