列表是一种常用的数据结构,如代办事项,十佳榜单等。当不需要在一个很长的序列中查找元素,或者对其排序时,列表显得尤其有用
前言
列表是一种常用的数据结构,如代办事项,十佳榜单等。当不需要在一个很长的序列中查找元素,或者对其排序时,列表显得尤其有用
实现
使用 TypeScript 实现列表类,要实现的的列表类是
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
| class List { pos: number listSize: number data: []
constructor() { this.pos = 0 this.listSize = 0 this.data = [] }
get length() { return this.listSize }
clear() {}
toString() {}
getElement() {}
insert() {}
append() {}
remove() {}
front() {}
end() {}
prev() {}
next() {}
hasNext() {}
hasPrev() {}
currentPos() {}
moveTo() {} }
|
将列表类实现后
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
| class List { pos: number data: Array<any> listSize: number
constructor() { this.pos = 0 this.listSize = 0 this.data = [] }
get length() { return this.listSize }
get currentPos() { return this.pos }
clear() { delete this.data this.data.length = this.listSize = this.pos = 0 }
toString() { return this.data.toString() }
getElement() { return this.data[this.pos] }
insert(element: any, after: any) { const index = this.findIndex(after)
if (index > -1) { this.data.splice(index + 1, 0, element) this.listSize += 1 return true }
return false }
append(element: any) { this.data.push(element) this.listSize += 1 }
remove(element: any) { const index = this.findIndex(element)
if (index > -1) { this.data.splice(index, 1) this.listSize -= 1 return true } return false }
contains(element: any) { return this.data.includes(element) }
front() { this.pos = 0 }
end() { this.pos = this.listSize - 1 }
prev() { if (this.pos > 0) { this.pos -= 1 } }
next() { if (this.pos < this.listSize) { this.pos += 1 } }
hasNext() { return this.pos < this.listSize }
hasPrev() { return this.pos > 0 }
moveTo(position: number) { if (position > 0 && position < this.listSize) { this.pos = position } }
private findIndex(element: any) { return this.data.findIndex(ele => element === ele) } }
|
测试
1 2 3 4 5 6 7 8 9
| const list = new List()
list.append('aaa') list.append('bbb') list.append('ccc') list.append('ddd') list.append('eee')
console.log('list :', list)
|
输出
1 2 3 4
| list : List { pos: 0, listSize: 5, data: [ 'aaa', 'bbb', 'ccc', 'ddd', 'eee' ] }
|