亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

PHP雙向鏈表定義與用法示例

2024-05-05 00:02:10
字體:
來源:轉載
供稿:網友

本文實例講述了PHP雙向鏈表定義與用法。分享給大家供大家參考,具體如下:

由于需要對一組數據多次進行移動操作,所以寫個雙向鏈表。但對php實在不熟悉,雖然測試各個方法沒啥問題,就是不知道php語言深層的這些指針和unset有什么注意的地方,貼出來讓大家教育吧。效率沒測試....求諒解~

<?php/** * **雙向鏈表 * @author zhiyuan12@ *//** * 鏈表元素結點類 */class Node_Element {  public $pre = NULL; // 前驅  public $next = NULL; // 后繼  public $key = NULL; // 元素鍵值  public $data = NULL; // 結點值  function __Construct($key, $data) {    $this->key = $key;    $this->data = $data;  }}/** * 雙向鏈表類 */class DoubleLinkedList {  private $head; // 頭指針  private $tail; // 尾指針  private $current; // 當前指針  private $len; // 鏈表長度  function __Construct() {    $this->head = self::_getNode ( null, null );    $this->curelement = $this->head;    $this->tail = $this->head;    $len = 0;  }  /**   * @ desc: 讀取鏈表全部結點   */  public function readAll() {    $tmp = $this->head;    while ( $tmp->next !== null ) {      $tmp = $tmp->next;      var_dump ( $tmp->key, $tmp->data );    }  }  public function move($pos1, $pos2) {    $pos1Node = $this->findPosition ( $pos1 );    $pos2Node = $this->findPosition ( $pos2 );    if ($pos1Node !== null && $pos2Node !== null) {      $tmpKey = $pos1Node->key;      $tmpData = $pos1Node->data;      $pos1Node->key = $pos2Node->key;      $pos1Node->data = $pos2Node->data;      $pos2Node->key = $tmpKey;      $pos2Node->data = $tmpData;      return true;    }    return false;  }  /**   * @ desc: 在指定關鍵詞刪除結點   *   * @param : $key   *     指定位置的鏈表元素key   */  public function delete($key) {    $pos = $this->find ( $key );    if ($pos !== null) {      $tmp = $pos;      $last = null;      $first = true;      while ( $tmp->next !== null && $tmp->next->key === $key ) {        $tmp = $tmp->next;        if (! $first) {          $this->delNode ( $last );        } else {          $first = false;        }        $last = $tmp;      }      if ($tmp->next !== null) {        $pos->pre->next = $tmp->next;        $tmp->next->pre = $pos->pre;      } else {        $pos->pre->next = null;      }      $this->delNode ( $pos );      $this->delNode ( $tmp );    }  }  /**   * @ desc: 在指定位置刪除結點   *   * @param : $key   *     指定位置的鏈表元素key   */  public function deletePosition($pos) {    $tmp = $this->findPosition ( $pos );    if ($tmp === null) {      return true;    }    if ($tmp === $this->getTail ()) {      $tmp->pre->next = null;      $this->delNode ( $tmp );      return true;    }    $tmp->pre->next = $tmp->next;    $tmp->next->pre = $tmp->pre;    $this->delNode ( $tmp );  }  /**   * @ desc: 在指定鍵值之前插入結點   *   * @param : $key   *     //指定位置的鏈表元素key   * @param : $data   *     //要插入的鏈表元素數據   * @param : $flag   *     //是否順序查找位置進行插入   */  public function insert($key, $data, $flag = true) {    $newNode = self::_getNode ( $key, $data );    $tmp = $this->find ( $key, $flag );    if ($tmp !== null) {      $newNode->pre = $tmp->pre;      $newNode->next = $tmp;      $tmp->pre = $newNode;      $newNode->pre->next = $newNode;    } else {      $newNode->pre = $this->tail;      $this->tail->next = $newNode;      $this->tail = $newNode;    }    $this->len ++;  }  /**   * @ desc: 在指定位置之前插入結點   *   * @param : $pos   *     指定插入鏈表的位置   * @param : $key   *     指定位置的鏈表元素key   * @param : $data   *     要插入的鏈表元素數據   */  public function insertPosition($pos, $key, $data) {    $newNode = self::_getNode ( $key, $data );    $tmp = $this->findPosition ( $pos );    if ($tmp !== null) {      $newNode->pre = $tmp->pre;      $newNode->next = $tmp;      $tmp->pre = $newNode;      $newNode->pre->next = $newNode;    } else {      $newNode->pre = $this->tail;      $this->tail->next = $newNode;      $this->tail = $newNode;    }    $this->len ++;    return true;  }  /**   * @ desc: 根據key值查詢指定位置數據   *   * @param : $key   *     //指定位置的鏈表元素key   * @param : $flag   *     //是否順序查找   */  public function find($key, $flag = true) {    if ($flag) {      $tmp = $this->head;      while ( $tmp->next !== null ) {        $tmp = $tmp->next;        if ($tmp->key === $key) {          return $tmp;        }      }    } else {      $tmp = $this->getTail ();      while ( $tmp->pre !== null ) {        if ($tmp->key === $key) {          return $tmp;        }        $tmp = $tmp->pre;      }    }    return null;  }  /**   * @ desc: 根據位置查詢指定位置數據   *   * @param : $pos   *     //指定位置的鏈表元素key   */  public function findPosition($pos) {    if ($pos <= 0 || $pos > $this->len)      return null;    if ($pos < ($this->len / 2 + 1)) {      $tmp = $this->head;      $count = 0;      while ( $tmp->next !== null ) {        $tmp = $tmp->next;        $count ++;        if ($count === $pos) {          return $tmp;        }      }    } else {      $tmp = $this->tail;      $pos = $this->len - $pos + 1;      $count = 1;      while ( $tmp->pre !== null ) {        if ($count === $pos) {          return $tmp;        }        $tmp = $tmp->pre;        $count ++;      }    }    return null;  }  /**   * @ desc: 返回鏈表頭節點   */  public function getHead() {    return $this->head->next;  }  /**   * @ desc: 返回鏈表尾節點   */  public function getTail() {    return $this->tail;  }  /**   * @ desc: 查詢鏈表節點個數   */  public function getLength() {    return $this->len;  }  private static function _getNode($key, $data) {    $newNode = new Node_Element ( $key, $data );    if ($newNode === null) {      echo "new node fail!";    }    return $newNode;  }  private function delNode($node) {    unset ( $node );    $this->len --;  }}$myList = new DoubleLinkedList ();$myList->insert ( 1, "test1" );$myList->insert ( 2, "test2" );$myList->insert ( "2b", "test2-b" );$myList->insert ( 2, "test2-c" );$myList->insert ( 3, "test3" );$myList->insertPosition ( 5, "t", "testt" );$myList->readAll ();echo "+++";$myList->deletePosition(0);$myList->readAll ();echo "..." . $myList->getLength ();var_dump ( $myList->findPosition ( 3 )->data );?>

運行結果:

int(1)string(5) "test1"int(2)string(7) "test2-c"int(2)string(5) "test2"string(2) "2b"string(7) "test2-b"string(1) "t"string(5) "testt"int(3)string(5) "test3"+++int(1)string(5) "test1"int(2)string(7) "test2-c"int(2)string(5) "test2"string(2) "2b"string(7) "test2-b"string(1) "t"string(5) "testt"int(3)string(5) "test3"...6string(5) "test2"

希望本文所述對大家PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久精品美女高潮| 久久天堂av综合合色| 成人a免费视频| 欧美日韩中文字幕在线视频| 欧美激情精品久久久久久免费印度| 川上优av一区二区线观看| 色噜噜狠狠狠综合曰曰曰| 亚洲xxxxx| 精品国产精品自拍| 精品亚洲永久免费精品| 最近2019中文字幕在线高清| 日本精品久久电影| 亚洲国产精品电影在线观看| 亚洲欧洲中文天堂| 成人久久精品视频| 久久精品成人欧美大片古装| 亲子乱一区二区三区电影| 亚洲福利影片在线| 国产亚洲欧洲高清一区| 另类天堂视频在线观看| 亚洲人成网站免费播放| 国产精欧美一区二区三区| 成人午夜一级二级三级| 91久久久精品| 国内精品模特av私拍在线观看| 国产成人av网| 91大神福利视频在线| 久久久久久久久久av| 精品亚洲va在线va天堂资源站| 国产精品欧美激情在线播放| 91精品国产乱码久久久久久蜜臀| 久久中文字幕一区| 欧美做受高潮1| 久久99国产精品自在自在app| 色偷偷9999www| 欧美视频在线观看免费网址| 性色av一区二区咪爱| 北条麻妃一区二区在线观看| 久久国产精品久久精品| 国产精品女主播| 91在线免费网站| 欧美日韩一区二区三区| 性视频1819p久久| 精品自拍视频在线观看| 永久免费看mv网站入口亚洲| 92看片淫黄大片欧美看国产片| 日韩高清免费在线| 欧美性生交xxxxxdddd| 成人字幕网zmw| 久久深夜福利免费观看| 国产精品爽黄69| 最近2019中文字幕大全第二页| 亚洲欧洲成视频免费观看| 国产热re99久久6国产精品| 亚洲二区在线播放视频| 亚洲成人精品久久| 亚洲第一网站免费视频| 国产精品视频区| 国产中文日韩欧美| 91亚洲午夜在线| 亚洲在线第一页| 92国产精品视频| 亚洲成人中文字幕| 国产精品久久久久久久久借妻| 国产女精品视频网站免费| 久久久精品在线| 97人洗澡人人免费公开视频碰碰碰| 亚洲国产成人在线播放| 日本电影亚洲天堂| 久久999免费视频| 正在播放欧美视频| 亚洲精美色品网站| 中文字幕日韩在线观看| 欧美中文在线视频| 欧美精品电影免费在线观看| 亚洲一级片在线看| 丝袜情趣国产精品| 欧美视频精品一区| 精品人伦一区二区三区蜜桃网站| 在线播放亚洲激情| 久久视频国产精品免费视频在线| 国产精品久久久久9999| 久久久天堂国产精品女人| 欧美麻豆久久久久久中文| 久久久久这里只有精品| 1769国产精品| 欧美在线视频免费观看| 日韩av免费看| 成人久久久久久久| 日韩精品在线免费观看| 青青草原成人在线视频| 久久久人成影片一区二区三区| 国产精品普通话| 正在播放国产一区| 欧美激情影音先锋| 亚洲性视频网站| 91精品国产综合久久香蕉最新版| 一本色道久久综合狠狠躁篇的优点| 久久久欧美精品| 欧美激情视频网址| 国产精品无av码在线观看| 欧美激情视频三区| 欧美精品成人91久久久久久久| 91精品久久久久久久久久| 国模视频一区二区三区| 日韩精品久久久久久久玫瑰园| 中文字幕精品www乱入免费视频| 最新国产成人av网站网址麻豆| 亚洲xxx视频| 亚洲自拍av在线| 久久精品中文字幕免费mv| 97国产精品久久| 亚洲欧美国内爽妇网| 欧美极度另类性三渗透| 亚洲娇小xxxx欧美娇小| 欧美激情精品久久久久久黑人| 色天天综合狠狠色| 成人一区二区电影| 亚洲人午夜精品| 性欧美xxxx| 91免费精品视频| 久久精品精品电影网| 国产精品亚洲精品| 91超碰caoporn97人人| 黑丝美女久久久| 精品亚洲va在线va天堂资源站| 91精品91久久久久久| 欧美激情欧美激情在线五月| 欧美午夜丰满在线18影院| 久操成人在线视频| 国产在线拍揄自揄视频不卡99| 国产精品色午夜在线观看| 亚洲欧美综合另类中字| 亚洲电影免费观看高清完整版在线观看| 最近免费中文字幕视频2019| 亚洲乱码国产乱码精品精| 国产精品日韩在线观看| 美女啪啪无遮挡免费久久网站| 日韩欧美在线免费观看| 日韩精品亚洲视频| 91在线无精精品一区二区| 欧美贵妇videos办公室| 亲爱的老师9免费观看全集电视剧| 日韩在线欧美在线| 日韩精品视频在线播放| 久久久久国产精品一区| 国产精品成人观看视频国产奇米| 国产一区二区三区四区福利| 日韩视频免费在线观看| 亚洲免费电影在线观看| 日韩成人中文字幕在线观看| 日韩欧美一区视频| 欧美日韩福利在线观看| 久久精品美女视频网站| 亚洲视频自拍偷拍| 欧美xxxx18性欧美| 国产精品视频自在线| 69国产精品成人在线播放| 亚洲精品国产suv| 欧美激情亚洲国产| 麻豆国产精品va在线观看不卡| 成人免费xxxxx在线观看| 97超级碰在线看视频免费在线看| 久久久久国产视频|