日界線是指日期的分界線,國際規(guī)定180度經(jīng)線,但這不是一條直線,是一條曲線
又是一個(gè)別人開心ipo痛哭的日子嗚嗚嗚
先講個(gè)故事,公元1世紀(jì)猶太戰(zhàn)爭(zhēng),猶太人被包圍了,不想被俘虜?shù)摹坝率俊睂幙勺詺ⅲ最I(lǐng)指著最近的一個(gè)說
‘從你開始往后數(shù),數(shù)到第三個(gè),他就自殺,再從他下一個(gè)開始數(shù),數(shù)到第三個(gè)自殺,后面的一樣,開始吧’
其中聰明的兩個(gè)人想辦法插隊(duì),不想就這樣死了(其中一個(gè)就是約瑟夫)
呵呵這是在告訴我“最困難的一刻,只要去想,總有解決的辦法”
來吧,看聰明的ipo怎么解決的
通用的,n個(gè)人,第m個(gè)自殺,留下的是第幾個(gè)呢
/* 實(shí)例 使用循環(huán)鏈表解決約瑟夫環(huán)問題 */ function lastTwo(n, m) { var list = new LList(); list.insert(1, "head"); for (var i = 2; i <= n; i++) { list.insert(i, i - 1); } var currNode = list.head.next; var removeNode = null; while (list.length >= m) { removeNode = move(currNode, m); list.remove(removeNode.value); currNode = removeNode.next; } return list.display(); } function move(currNode, m) { for (var i = 1; i < m; i++) { if (currNode.value === "head") { i -= 1; } currNode = currNode.next; } return currNode; } lastTwo(3, 3);
實(shí)現(xiàn)原理是什么的,慢慢從基礎(chǔ)理解
單向鏈表
主要闡述了鏈表是怎么一回事:節(jié)點(diǎn)+鏈
上代碼:
function Node(elem) { //兩個(gè)類:Node當(dāng)前節(jié)點(diǎn)數(shù)據(jù)以及下一個(gè)節(jié)點(diǎn)的引用,LList頭節(jié)點(diǎn)以及操作鏈表的方法 this.elem = elem; this.next = null; } function LList() { this.head = new Node("head"); this.find = find; this.findPrevious = findPrevious; this.insert = insert; this.remove = remove; this.display = display; } function find(item) { var currNode = this.head; while (currNode.elem !== item) { currNode = currNode.next; } return currNode; } function findPrevious(item) { var currNode = this.head; while (currNode.next !== null && currNode.next.elem !== item) { currNode = currNode.next; } return currNode; } function insert(newElem, item) { var newNode = new Node(newElem); var currNode = this.find(item); newNode.next = currNode.next; currNode.next = newNode; } function remove(item) { var prevNode = this.findPrevious(item); if (prevNode.next !== null) { prevNode.next = prevNode.next.next; } } function display() { var currNode = this.head; while (currNode.next !== null) { console.log(currNode.next.elem); currNode = currNode.next; } } /* 創(chuàng)建一個(gè)實(shí)例 */ var cities = new LList(); cities.insert("Conway", "head"); cities.insert("Russellville", "Conway"); cities.display();
今天進(jìn)行了如下優(yōu)化,封裝,繼承
/* 鏈表=節(jié)點(diǎn)+鏈 節(jié)點(diǎn)=節(jié)點(diǎn)值+next(節(jié)點(diǎn)的引用指向后繼) 鏈=頭結(jié)點(diǎn)聲明初始化+方法+屬性 */ (function(window) { function Node(value) { this.value = value; this.next = null; } var uList = function() { this.head = new Node("head"); this.length = 0; }; uList.prototype.find = function(value) { if (value === "head") { return this.head; } var currNode = this.head.next; while (currNode !== null) { if (currNode.value === value) { return currNode; } else { currNode = currNode.next; } } return -1; }; uList.prototype.insert = function(newValue, currValue) { var newNode = new Node(newValue); var currNode = this.find(currValue); if (currNode !== -1) { newNode.next = currNode.next; currNode.next = newNode; } else { alert("未找到要插入的位置元素"); } }; uList.prototype.findPrevious = function(value) { if (value === "head") { return -1; } var currNode = this.head; while (currNode.next !== null) { if (currNode.next.value === value) { return currNode; } else { currNode = currNode.next; } } return -1; }; uList.prototype.remove = function(value) { var currNode = this.find(value); if (currNode !== -1) { var preNode = this.findPrevious(value); if (preNode !== -1) { preNode.next = currNode.next; } else { alert("未找到刪除的元素"); } } else { alert("未找到刪除的元素"); } }; uList.prototype.display = function() { var currNode = this.head.next; while (currNode !== null) { console.log(currNode.value); currNode = currNode.next; } }; var List = function() { uList.call(List); }; List.prototype = new uList(); window.List = List; })(window); /* 試一下 */ var mylist = new List(); mylist.insert(1, "head"); mylist.display();
單向鏈表是最簡(jiǎn)單的鏈表,JS中把數(shù)組搞成對(duì)象,性能勢(shì)必不行了,可以自己造個(gè)鏈表替代數(shù)組。不過隨機(jī)訪問一個(gè)元素還是數(shù)組好些。
雙向鏈表
雙向鏈表比單向鏈表相比node多了前置引用,方法刪除操作修改next的同時(shí)要修改pre
function Node(elem){ this.elem=elem; this.previous=null; this.next=null; } function LList(){ this.head=new Node("head"); this.find=find; this.findPrevious=findPrevious; this.insert=insert; this.remove=remove; this.display=display; this.displayReverse=displayReverse; } function find(elem){ var currNode=this.head; while(currNode.elem!==elem&&currNode.next!==null){ currNode=currNode.next; } return currNode; } function findPrevious(){ var currNode=this.head; while(currNode.next!==null){ currNode=currNode.next; } return currNode; } function insert(newElem,item){ var currNode=this.find(item); var newNode=new Node(newElem); if(currNode.next!==null){ currNode.next.previous=newNode; newNode.next=currNode.next; } newNode.previous=currNode; currNode.next=newNode; } function remove(elem){ var currNode=this.find(elem); if(currNode.next!==null){ currNode.next.previous=currNode.previous; } currNode.previous.next=currNode.next; } function display(){ var currNode=this.head; while(currNode.next!==null){ console.log(currNode.next.elem); currNode=currNode.next; } } function displayReverse(){ var currNode=this.findPrevious(); while(currNode.previous!==null){ console.log(currNode.previous.elem); currNode=currNode.previous; } }
循環(huán)鏈表
循環(huán)鏈表與單向鏈表相比,強(qiáng)調(diào)最后一個(gè)節(jié)點(diǎn)的引用后繼是head,所以初始化鏈表時(shí)頭結(jié)點(diǎn)時(shí)后繼是head本身
function Node(elem){ this.elem=elem; this.next=null; } function LList(){ this.head=new Node("head"); this.head.next=this.head; this.find=find; this.insert=insert; this.findPrevious=findPrevious; this.remove=remove; this.display=display; } function find(elem){ var currNode=this.head; while(currNode.next!==this.head&&currNode.elem!==elem){ currNode=currNode.next; } return currNode; } function insert(newElem,item){ var currNode=this.find(item); var newNode=new Node(newElem); if(currNode.next!==this.head){ newNode.next=currNode.next; currNode.next=newNode; }else{ currNode.next=newNode; newNode.next=this.head; } } function findPrevious(elem){ var currNode=this.head; while(currNode.next.elem!==elem){ currNode=currNode.next; } return currNode; } function remove(elem){ var prevNode=this.findPrevious(elem); var currNode=this.find(elem); prevNode.next=currNode.next; } function display(){ var currNode=this.head; while(currNode.next!==this.head){ console.log(currNode.next.elem); currNode=currNode.next; } }
優(yōu)化一下就是文章開頭的例子中用到的了
(function(window) { function Node(value) { this.value = value; this.next = null; } function list() { this.head = new Node("head"); this.head.next = this.head; this.length = 0; } list.prototype.find = function(elem) { if (elem === "head") { return this.head; } var curr = this.head.next; while (curr !== this.head) { if (curr.value === elem) { return curr; } else { curr = curr.next; } } return -1; }; list.prototype.insert = function(newValue, currValue) { var newNode = new Node(newValue); var currNode = this.find(currValue); if (currNode === -1) { alert("未找到插入位置的元素"); } else { newNode.next = currNode.next; currNode.next = newNode; this.length++; } }; list.prototype.findPrevious = function(currValue) { if (this.head.next.value === currValue) { return this.head; } var curr = this.head.next; while (curr !== this.head) { if (curr.next.value === currValue) { return curr; } else { curr = curr.next; } } return -1; }; list.prototype.remove = function(elem) { var curr = this.find(elem); if (curr === -1) { alert("找不到要?jiǎng)h除的元素"); } else { var pre = this.findPrevious(elem); if (pre === -1) { alert("找不到要?jiǎng)h除的元素"); } else { pre.next = curr.next; this.length--; } } }; list.prototype.display = function() { var curr = this.head; while (curr.next !== this.head) { console.log(curr.next.value); curr = curr.next; } }; var LList = function() { list.call(LList); }; LList.prototype = new list(); window.LList = LList; })(window);
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/80835.html
摘要:基本點(diǎn)數(shù)據(jù)結(jié)構(gòu)本來制作的是腦圖,思維導(dǎo)圖,導(dǎo)出來不好上傳,就這樣吧基本的數(shù)據(jù)類型區(qū)別區(qū)別表示聲明了一個(gè)變量,沒有初始化的情況下輸出該變量為以及未聲明直接一個(gè)未聲明的變量結(jié)果也為中的變量是弱類型的,中聲明一個(gè)即使未賦值也會(huì)自動(dòng)初始化為類型的并 基本點(diǎn) 數(shù)據(jù)結(jié)構(gòu) 本來制作的是腦圖,思維導(dǎo)圖,導(dǎo)出來不好上傳,就這樣md+png吧 showImg(https://segmentfault.co...
摘要:尤其是喬布斯在年發(fā)布的一篇的文章。喬布斯在里面寫下了關(guān)于的一點(diǎn)看法,說明自己為什么不使用,談到關(guān)于的一些問題,比如開放性,安全性,對(duì)于設(shè)備續(xù)航的影響,不利于觸摸屏,等等。終于,于年月日,爸爸也放棄治療了,宣布將于年正式退休。 今天為大家分享一下html5中的視頻(video)與音頻(audio)。在進(jìn)入主題之前我們先了解一下Flash與html5這兩種技術(shù)的時(shí)代背景與發(fā)展歷史。 1.前...
摘要:尤其是喬布斯在年發(fā)布的一篇的文章。喬布斯在里面寫下了關(guān)于的一點(diǎn)看法,說明自己為什么不使用,談到關(guān)于的一些問題,比如開放性,安全性,對(duì)于設(shè)備續(xù)航的影響,不利于觸摸屏,等等。終于,于年月日,爸爸也放棄治療了,宣布將于年正式退休。 今天為大家分享一下html5中的視頻(video)與音頻(audio)。在進(jìn)入主題之前我們先了解一下Flash與html5這兩種技術(shù)的時(shí)代背景與發(fā)展歷史。 1.前...
摘要:尤其是喬布斯在年發(fā)布的一篇的文章。喬布斯在里面寫下了關(guān)于的一點(diǎn)看法,說明自己為什么不使用,談到關(guān)于的一些問題,比如開放性,安全性,對(duì)于設(shè)備續(xù)航的影響,不利于觸摸屏,等等。終于,于年月日,爸爸也放棄治療了,宣布將于年正式退休。 今天為大家分享一下html5中的視頻(video)與音頻(audio)。在進(jìn)入主題之前我們先了解一下Flash與html5這兩種技術(shù)的時(shí)代背景與發(fā)展歷史。 1.前...
閱讀 973·2021-11-24 10:42
閱讀 3522·2021-11-19 11:34
閱讀 2657·2021-09-29 09:35
閱讀 2542·2021-09-09 09:33
閱讀 688·2021-07-26 23:38
閱讀 2531·2019-08-30 10:48
閱讀 1398·2019-08-28 18:07
閱讀 433·2019-08-26 13:44