123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 |
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- /**
- * Refactored implementation of LinkedList (part of javascript-algorithms project) by Github users:
- * mgechev, AndriiHeonia, Microfed and Jakeh (part of javascript-algorithms project - all project contributors
- * at repository website)
- *
- * Link to repository: https://github.com/mgechev/javascript-algorithms
- */
- /**
- * Linked list node.
- *
- * @class NodeStructure
- * @util
- */
- var NodeStructure = function NodeStructure(data) {
- _classCallCheck(this, NodeStructure);
- /**
- * Data of the node.
- * @member {Object}
- */
- this.data = data;
- /**
- * Next node.
- * @member {NodeStructure}
- */
- this.next = null;
- /**
- * Previous node.
- * @member {NodeStructure}
- */
- this.prev = null;
- };
- /**
- * Linked list.
- *
- * @class LinkedList
- * @util
- */
- var LinkedList = function () {
- function LinkedList() {
- _classCallCheck(this, LinkedList);
- this.first = null;
- this.last = null;
- }
- /**
- * Add data to the end of linked list.
- *
- * @param {Object} data Data which should be added.
- */
- _createClass(LinkedList, [{
- key: "push",
- value: function push(data) {
- var node = new NodeStructure(data);
- if (this.first === null) {
- this.first = node;
- this.last = node;
- } else {
- var temp = this.last;
- this.last = node;
- node.prev = temp;
- temp.next = node;
- }
- }
- /**
- * Add data to the beginning of linked list.
- *
- * @param {Object} data Data which should be added.
- */
- }, {
- key: "unshift",
- value: function unshift(data) {
- var node = new NodeStructure(data);
- if (this.first === null) {
- this.first = node;
- this.last = node;
- } else {
- var temp = this.first;
- this.first = node;
- node.next = temp;
- temp.prev = node;
- }
- }
- /**
- * In order traversal of the linked list.
- *
- * @param {Function} callback Callback which should be executed on each node.
- */
- }, {
- key: "inorder",
- value: function inorder(callback) {
- var temp = this.first;
- while (temp) {
- callback(temp);
- temp = temp.next;
- }
- }
- /**
- * Remove data from the linked list.
- *
- * @param {Object} data Data which should be removed.
- * @returns {Boolean} Returns true if data has been removed.
- */
- }, {
- key: "remove",
- value: function remove(data) {
- if (this.first === null) {
- return false;
- }
- var temp = this.first;
- var next = void 0;
- var prev = void 0;
- while (temp) {
- if (temp.data === data) {
- next = temp.next;
- prev = temp.prev;
- if (next) {
- next.prev = prev;
- }
- if (prev) {
- prev.next = next;
- }
- if (temp === this.first) {
- this.first = next;
- }
- if (temp === this.last) {
- this.last = prev;
- }
- return true;
- }
- temp = temp.next;
- }
- return false;
- }
- /**
- * Check if linked list contains cycle.
- *
- * @returns {Boolean} Returns true if linked list contains cycle.
- */
- }, {
- key: "hasCycle",
- value: function hasCycle() {
- var fast = this.first;
- var slow = this.first;
- while (true) {
- if (fast === null) {
- return false;
- }
- fast = fast.next;
- if (fast === null) {
- return false;
- }
- fast = fast.next;
- slow = slow.next;
- if (fast === slow) {
- return true;
- }
- }
- }
- }, {
- key: "pop",
- /**
- * Return last node from the linked list.
- *
- * @returns {NodeStructure} Last node.
- */
- value: function pop() {
- if (this.last === null) {
- return null;
- }
- var temp = this.last;
- this.last = this.last.prev;
- return temp;
- }
- }, {
- key: "shift",
- /**
- * Return first node from the linked list.
- *
- * @returns {NodeStructure} First node.
- */
- value: function shift() {
- if (this.first === null) {
- return null;
- }
- var temp = this.first;
- this.first = this.first.next;
- return temp;
- }
- }, {
- key: "recursiveReverse",
- /**
- * Reverses the linked list recursively
- */
- value: function recursiveReverse() {
- function inverse(current, next) {
- if (!next) {
- return;
- }
- inverse(next, next.next);
- next.next = current;
- }
- if (!this.first) {
- return;
- }
- inverse(this.first, this.first.next);
- this.first.next = null;
- var temp = this.first;
- this.first = this.last;
- this.last = temp;
- }
- }, {
- key: "reverse",
- /**
- * Reverses the linked list iteratively
- */
- value: function reverse() {
- if (!this.first || !this.first.next) {
- return;
- }
- var current = this.first.next;
- var prev = this.first;
- var temp = void 0;
- while (current) {
- temp = current.next;
- current.next = prev;
- prev.prev = current;
- prev = current;
- current = temp;
- }
- this.first.next = null;
- this.last.prev = null;
- temp = this.first;
- this.first = prev;
- this.last = temp;
- }
- }]);
- return LinkedList;
- }();
- ;
- export { NodeStructure };
- export default LinkedList;
|