當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Node::setNext方法代碼示例

本文整理匯總了PHP中Node::setNext方法的典型用法代碼示例。如果您正苦於以下問題:PHP Node::setNext方法的具體用法?PHP Node::setNext怎麽用?PHP Node::setNext使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Node的用法示例。


在下文中一共展示了Node::setNext方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: testGetIntersectingNode

 public function testGetIntersectingNode()
 {
     $a1 = new Node("one");
     $a2 = new Node("two");
     $a3 = new Node("three");
     $a4 = new Node("four");
     $a5 = new Node("five");
     $a1->setNext($a2);
     $a2->setNext($a3);
     $a3->setNext($a4);
     $a4->setNext($a5);
     $b1 = new Node("un");
     $b2 = new Node("deux");
     $b3 = new Node("trois");
     $b1->setNext($b2);
     $b2->setNext($b3);
     $this->assertNull(LinkedListIntersectionChecker::getIntersectingNode($a1, $b1));
     $c1 = new Node("uno");
     $c2 = new Node("dos");
     $c3 = new Node("tres");
     $c1->setNext($c2);
     $c2->setNext($c3);
     $a5->setNext($c1);
     $b3->setNext($c1);
     $this->assertSame($c1, LinkedListIntersectionChecker::getIntersectingNode($a1, $b1));
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:26,代碼來源:LinkedListIntersectionCheckerTest.php

示例2: testGetIntersectingNode

 public function testGetIntersectingNode()
 {
     $a1 = new Node("one");
     $a2 = new Node("two");
     $a3 = new Node("three");
     $a4 = new Node("four");
     $a5 = new Node("five");
     $a1->setNext($a2);
     $a2->setNext($a3);
     $a3->setNext($a4);
     $a4->setNext($a5);
     $b1 = new Node("un");
     $b2 = new Node("deux");
     $b3 = new Node("trois");
     $b1->setNext($b2);
     $b2->setNext($b3);
     $this->assertNull(LinkedListIntersectionCheckerNoHashMap::getIntersectingNode($a1, $b1));
     $c1 = new Node("uno");
     $c2 = new Node("dos");
     $c3 = new Node("tres");
     $c1->setNext($c2);
     $c2->setNext($c3);
     $a5->setNext($c1);
     $b3->setNext($c1);
     $this->assertSame($c1, LinkedListIntersectionCheckerNoHashMap::getIntersectingNode($a1, $b1));
     // disconnect the first 4 nodes of the linked list.
     // now it begins @ $a5
     $a4->setNext(null);
     $this->assertSame($c1, LinkedListIntersectionCheckerNoHashMap::getIntersectingNode($a5, $b1));
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:30,代碼來源:LinkedListIntersectionCheckerNoHashMapTest.php

示例3: push

 public function push($value)
 {
     $newHead = new Node($value);
     $newHead->setNext($this->linkedList);
     $this->linkedList = $newHead;
     $this->size++;
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:7,代碼來源:SizedStack.php

示例4: __construct

 /**
  * All object initialized with NULL as its head.
  *
  * @return void
  */
 public function __construct()
 {
     // Sentinel is dummy object before head and after tail.
     $sentinel = new Node(NULL);
     $sentinel->setNext($sentinel);
     $sentinel->setPrev($sentinel);
     $this->_sentinel = $sentinel;
     $this->_head = $this->_sentinel;
 }
開發者ID:Baft,項目名稱:Algorithm-and-Data-Structure-in-PHP,代碼行數:14,代碼來源:linked_list_using_class.php

示例5: deleteNodeFromLinkedList

 public static function deleteNodeFromLinkedList(Node $node)
 {
     if ($node === null) {
         throw new InvalidArgumentException('node is null');
     }
     $next = $node->getNext();
     if ($next === null) {
         throw new InvalidArgumentException('node is not in the middle of a linked list');
     }
     // overwrite values in the deleted node with the ones from the next node.
     $node->setData($next->getData());
     $node->setNext($next->getNext());
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:13,代碼來源:MiddleNodeDeleter.php

示例6: toLinkedListOfDigits

 public static function toLinkedListOfDigits($number)
 {
     $head = null;
     $base = 1;
     while ($number > 0) {
         $nextBase = $base * 10;
         $remainder = $number % $nextBase;
         $digit = new Node($remainder / $base);
         $digit->setNext($head);
         $head = $digit;
         $number -= $remainder;
         $base = $nextBase;
     }
     return $head;
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:15,代碼來源:SumListReversed.php

示例7: testGetIntersectingNode

 public function testGetIntersectingNode()
 {
     $n1 = new Node("one");
     $n2 = new Node("two");
     $n3 = new Node("three");
     $n4 = new Node("four");
     $n5 = new Node("five");
     $n1->setNext($n2);
     $n2->setNext($n3);
     $n3->setNext($n4);
     $n4->setNext($n5);
     $this->assertNull(LinkedListCycleDetector::getCycleNode($n1));
     // create a cycle
     $n5->setNext($n3);
     $this->assertSame($n3, LinkedListCycleDetector::getCycleNode($n1));
 }
開發者ID:rockhx1987,項目名稱:CtCI-6th-Edition,代碼行數:16,代碼來源:LinkedListCycleDetectorTest.php

示例8: push

 public function push($value)
 {
     $newHead = new Node($value);
     if ($this->linkedList === null) {
         $this->linkedList = $newHead;
         $this->min = new Node($value);
     } else {
         $newHead->setNext($this->linkedList);
         $this->linkedList = $newHead;
         if ($value < $this->min->getData()) {
             $newMin = new Node($value);
             $newMin->setNext($this->min);
             $this->min = $newMin;
         }
     }
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:16,代碼來源:StackMin.php

示例9: partition

 public static function partition(Node $node, $x)
 {
     $head = $node;
     $previousNode = null;
     while ($node !== null) {
         if ($node->getData() < $x && $previousNode !== null) {
             // remove the node from this part of the list
             $previousNode->setNext($node->getNext());
             // put this node at the begining of the list
             $node->setNext($head);
             // reset head
             $head = $node;
             // reset node for the next iteration
             $node = $previousNode;
         } else {
             $previousNode = $node;
             $node = $node->getNext();
         }
     }
     return $head;
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:21,代碼來源:LinkedListPartitioner.php

示例10: ListInsert

 public function ListInsert($i, $data)
 {
     //後插
     $j = 1;
     //從第一個元素開始遍曆
     $node = $this->_headNode;
     // 指向頭結點
     while ($node && $j < $i) {
         $node = $node->getNext();
         $j++;
     }
     if (!$node || $j > $i) {
         // $i個結點不存在時
         return "err";
     }
     $newNode = new Node();
     $newNode->setData($data);
     $newNode->setNext($node->getNext());
     $node->setNext($newNode);
     return true;
 }
開發者ID:Code-Ken,項目名稱:Data-Structures-And-Algorithms-With-PHP,代碼行數:21,代碼來源:SingleLinkedList.class.php

示例11: testSumWithMultipleCarryOperations

 public function testSumWithMultipleCarryOperations()
 {
     $a1 = new Node(1);
     $b1 = new Node(9);
     $b2 = new Node(9);
     $b3 = new Node(9);
     $b4 = new Node(9);
     $b5 = new Node(9);
     $b1->setNext($b2);
     $b2->setNext($b3);
     $b3->setNext($b4);
     $b4->setNext($b5);
     $node = SumListNoConvert::sum($a1, $b1);
     $this->assertEquals(0, $node->getData());
     $node = $node->getNext();
     $this->assertEquals(0, $node->getData());
     $node = $node->getNext();
     $this->assertEquals(0, $node->getData());
     $node = $node->getNext();
     $this->assertEquals(0, $node->getData());
     $node = $node->getNext();
     $this->assertEquals(0, $node->getData());
     $node = $node->getNext();
     $this->assertEquals(1, $node->getData());
     $node = $node->getNext();
     $this->assertNull($node);
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:27,代碼來源:SumListNoConvertTest.php

示例12: attach

 /**
  * Adds a node to the head of the list
  * @param Node $head the node object that represents the head of the list
  * @param Node $node the node to move to the head of the list
  */
 private function attach($head, $node)
 {
     $node->setPrevious($head);
     $node->setNext($head->getNext());
     $node->getNext()->setPrevious($node);
     $node->getPrevious()->setNext($node);
 }
開發者ID:jhammer,項目名稱:php-lrucache,代碼行數:12,代碼來源:LRUCache.php

示例13: testToInteger

 public function testToInteger()
 {
     $n1 = new Node(6);
     $n2 = new Node(1);
     $n3 = new Node(7);
     $n1->setNext($n2);
     $n2->setNext($n3);
     $this->assertEquals(617, SumListReversed::toInteger($n1));
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:9,代碼來源:SumListReversedTest.php

示例14: testFindBeginningOfCycleWithCircularListOfSizeFive

 public function testFindBeginningOfCycleWithCircularListOfSizeFive()
 {
     $n1 = new Node("one");
     $n2 = new Node("two");
     $n3 = new Node("three");
     $n4 = new Node("four");
     $n5 = new Node("five");
     $n1->setNext($n2);
     $n2->setNext($n3);
     $n3->setNext($n4);
     $n4->setNext($n5);
     $n5->setNext($n1);
     $cycleNode = LinkedListCycleDetector::findBeginningOfCycle($n1);
     $this->assertSame($n1, $cycleNode, 'Expected: ' . $n1->getData() . ' Found: ' . $cycleNode->getData());
 }
開發者ID:SamyGhannad,項目名稱:CtCI-6th-Edition,代碼行數:15,代碼來源:LinkedListCycleDetectorTest.php


注:本文中的Node::setNext方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。