Rumah pembangunan bahagian belakang tutorial php PHP中模拟链表和链表的基本操作示例_php实例

PHP中模拟链表和链表的基本操作示例_php实例

Jun 07, 2016 pm 05:09 PM
php senarai terpaut

模拟链表:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

<&#63;php

/**

 * PHP实现链表的基本操作

 */

class linkList {

  /**

   * 姓名

   * @var string

   */

  public $name = '';

    

  /**

   * 编号

   * @var int

   */

  public $id = 0;

    

  /*

   * 引用下一个对象

   */

  public $next = null;

    

  /**

   * 构造函数初始化数据

   * @param int $id

   * @param string $name

   */

  public function __construct($id = 0, $name = '') {

    $this->name = $name;

    $this->id  = $id;

  }

    

  /**

   * 遍历链表

   */

  public static function echo_link_list($head) {

    $curr = $head;

    while ($curr->next != null) {

      echo '姓名:'.$curr->next->name, ' 编号:'.$curr->next->id;

      echo '<br>';

      $curr = $curr->next;

    }

  }

    

  /**

   * 添加新节点

   */

  public static function add($head, $id, $name) {

    $curr = $head;

    $obj = new linkList($id, $name);

      

    while ($curr->next != null) {

      // 如果当前ID < 下一个ID,则添加到中间,添加节点到指定顺序位置

      if ($curr->next->id > $id) {

          

        $obj->next = $curr->next;

        $curr->next = $obj;

          

        return true;

      } else if ($curr->next->id == $id) {

          

        echo '当前Id:'.$id.'重复了,请不要继续添加了!';

        echo '<br>';

          

        return false;

      }

      $curr = $curr->next;

    }

    // 添加节点到尾部

    if ($curr->next == null) {

      $curr->next = $obj;

    }

  }

    

  /**

   * 删除节点

   */

  public static function del($head, $id) {

    $curr = $head;

      

    while($curr->next != null) {

      if ($curr->next->id == $id) {

        $curr->next = $curr->next->next;

        return true;

      }

      $curr = $curr->next;

    }

  }

    

  /**

   * 修改节点

   */

  public static function edit($head, $id, $new_name) {

    $curr = $head;

      

    while($curr->next != null) {

      if ($curr->next->id == $id) {

        $curr->next->name = $new_name;

      }

      $curr = $curr->next;

    }

  }

}

  

$head = new linkList();

linkList::add($head, 1, 'wangdk');

linkList::add($head, 2, 'sunshuzhen');

linkList::add($head, 8, 'wanghaha');

linkList::add($head, 6, 'wangchufen');

linkList::add($head, 6, 'wangchufen');

linkList::add($head, 3, 'wangdaye');

  

linkList::del($head, 1);

linkList::edit($head, 2, 'hahaha');

linkList::echo_link_list($head);

  

&#63;>

Salin selepas log masuk

链表的增删查改:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

<&#63;php

/**

 * PHP实现链表的基本操作

 */

class linkList {

  /**

   * 姓名

   * @var string

   */

  public $name = '';

    

  /**

   * 编号

   * @var int

   */

  public $id = 0;

    

  /*

   * 引用下一个对象

   */

  public $next = null;

    

  /**

   * 构造函数初始化数据

   * @param int $id

   * @param string $name

   */

  public function __construct($id = 0, $name = '') {

    $this->name = $name;

    $this->id  = $id;

  }

    

  /**

   * 遍历链表

   */

  public static function echo_link_list($head) {

    $curr = $head;

    while ($curr->next != null) {

      echo '姓名:'.$curr->next->name, ' 编号:'.$curr->next->id;

      echo '<br>';

      $curr = $curr->next;

    }

  }

    

  /**

   * 添加新节点

   */

  public static function add($head, $id, $name) {

    $curr = $head;

    $obj = new linkList($id, $name);

      

    while ($curr->next != null) {

      // 如果当前ID < 下一个ID,则添加到中间,添加节点到指定顺序位置

      if ($curr->next->id > $id) {

          

        $obj->next = $curr->next;

        $curr->next = $obj;

          

        return true;

      } else if ($curr->next->id == $id) {

          

        echo '当前Id:'.$id.'重复了,请不要继续添加了!';

        echo '<br>';

          

        return false;

      }

      $curr = $curr->next;

    }

    // 添加节点到尾部

    if ($curr->next == null) {

      $curr->next = $obj;

    }

  }

    

  /**

   * 删除节点

   */

  public static function del($head, $id) {

    $curr = $head;

      

    while($curr->next != null) {

      if ($curr->next->id == $id) {

        $curr->next = $curr->next->next;

        return true;

      }

      $curr = $curr->next;

    }

  }

    

  /**

   * 修改节点

   */

  public static function edit($head, $id, $new_name) {

    $curr = $head;

      

    while($curr->next != null) {

      if ($curr->next->id == $id) {

        $curr->next->name = $new_name;

      }

      $curr = $curr->next;

    }

  }

}

  

$head = new linkList();

linkList::add($head, 1, 'wangdk');

linkList::add($head, 2, 'sunshuzhen');

linkList::add($head, 8, 'wanghaha');

linkList::add($head, 6, 'wangchufen');

linkList::add($head, 6, 'wangchufen');

linkList::add($head, 3, 'wangdaye');

  

linkList::del($head, 1);

linkList::edit($head, 2, 'hahaha');

linkList::echo_link_list($head);

  

&#63;>

Salin selepas log masuk

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Tarikh dan Masa CakePHP

Konfigurasi Projek CakePHP Konfigurasi Projek CakePHP Sep 10, 2024 pm 05:25 PM

Konfigurasi Projek CakePHP

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Muat naik Fail CakePHP

Penghalaan CakePHP Penghalaan CakePHP Sep 10, 2024 pm 05:25 PM

Penghalaan CakePHP

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

Bincangkan CakePHP

Panduan Ringkas CakePHP Panduan Ringkas CakePHP Sep 10, 2024 pm 05:27 PM

Panduan Ringkas CakePHP

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP

See all articles