寫了一個(gè)選擇排序的函數(shù),正常的傳入數(shù)字或者字母都是可以的,但是有沒有可能改我自定義類型的?
function px(array) {
for (let i = 0; i < array.length; i++) {
let minIndex = i;
for (let j = i + 1; j < array.length; j++) {
if (array[j] < array[minIndex]) {
minIndex = j;
}
}
[array[minIndex], array[i]] = [array[i], array[minIndex]]
}
return array;
}
假設(shè)現(xiàn)在我希望傳入一組學(xué)生的信息,來進(jìn)行排序[{ 'D': 90 }, { 'A': 20 }, { 'B': 50 }, { 'C': 10 }]
希望輸出[{ 'C': 10 }, { 'A': 20 }, { 'B': 50 }, { 'D': 90 }]
我想像這樣改成一個(gè)自定義類型的,我應(yīng)該怎么做,如何自定義這個(gè)類型~
先說答案: 有可能。但是需要調(diào)用者傳入更多的信息。
先來分析一下排序需要指導(dǎo)哪些信息:
我們看一下v8引擎給我們提供的接口,Array.prototype.sort():
sort() 方法在適當(dāng)?shù)奈恢脤?shù)組的元素進(jìn)行排序,并返回?cái)?shù)組。 sort 排序不一定是穩(wěn)定的。默認(rèn)排序順序是根據(jù)字符串Unicode碼點(diǎn)。arr.sort() arr.sort(compareFunction)
這個(gè)接口要求我們傳入一個(gè)compareFunction。也就是我前面所說的campare,那么swap和len呢?因?yàn)槭菍?shù)組進(jìn)行排序,那么Array這個(gè)類型信息中已經(jīng)包含了這倆個(gè)function,swap 就是直接交換。 len 就是 Array.length。所以你可以模仿這這個(gè)接口完成你自己的排序功能,進(jìn)行比較的時(shí)候,調(diào)用函數(shù)傳入的campare function 而不是 '<'或者 '>'。那么問題你的問題就解決了。排序函數(shù)的調(diào)用者每次為自己的類型多寫一個(gè)campare function 就可以復(fù)用 這個(gè)排序函數(shù)。看一下你給出來的c++的例子,運(yùn)算符重載'<',不正是傳進(jìn)去的那個(gè)campare function 嗎? 只是語言的語法不同導(dǎo)致的表達(dá)方式的不同而已,所需要的信息從來沒有變過。
既然說到了這里,就展開來說一下len, 和 swap 怎么使用。 前面我們所講的都是多數(shù)組進(jìn)行排序。我想為自己寫的一個(gè)鏈表進(jìn)行排序,怎么辦呢? 那么你再傳入len, swap 就可以了len 獲取長度,swap 交換元素。我們的排序函數(shù)就能更好的復(fù)用了。當(dāng)然了這樣寫的話就會顯得又臭又長,而且js中我們一般也不會自己去寫一個(gè)鏈表,Array可以當(dāng)鏈表用。
開拓一下眼界,看看在別的語言是怎么做的。在java中因?yàn)橛薪涌谶@一語法,所以就讓你實(shí)現(xiàn)comparable 這個(gè)接口,這個(gè)接口中有什么函數(shù)呢?就一個(gè)campareTo;golang中 讓你去實(shí)現(xiàn)sort.Interface這個(gè)接口,這個(gè)接口中有我前面提到的三個(gè)函數(shù)。
如果能修改對象的形式,這樣能容易很多
[{name:'D',score: 90 }, { name:'A',score: 20 }, { name:'B','score': 50 }, { name:'C','score': 10 }].sort((a,b)=>{return a.score-b.score})
學(xué)到了,借鑒樓上的Object.keys()方法
[{ 'D': 90 }, { 'A': 20 }, { 'B': 50 }, { 'C': 10 }].sort((a,b)=>{return a[Object.keys(a)]-b[Object.keys(b)]})
function px(array, Fn) {
array = Fn(array);
for (let i = 0; i < array.length; i++) {
let minIndex = i;
for (let j = i + 1; j < array.length; j++) {
if (array[j] < array[minIndex]) {
minIndex = j;
}
}
[array[minIndex], array[i]] = [array[i], array[minIndex]]
}
return array;
}
function values(o) {
return Object.keys(o).map(
function(k) {
return o[k]
})
}
let array = [{ D: 90 }, { A: 20 }, { B: 50 }, { C: 10 }];
let item = px(array, (arr) => {
for (let i = 0; i < arr.length; i++) {
arr[i] = values(arr[i])[0];
}
return array;
});
console.log(item);
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。