deno.land / x / masx200_leetcode_test@10.6.5 / flatten-nested-list-iterator / index.ts

نووسراو ببینە
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
import { NestedInteger } from "../mini-parser/NestedInteger.ts";
export function* NestedIntegerIterator( nestedList: NestedInteger[],): Generator<number | null, void, unknown> { for (const nestedInteger of nestedList) { if (nestedInteger.isInteger()) { yield nestedInteger.getInteger(); } else { yield* NestedIntegerIterator(nestedInteger.getList()); } }}class NestedIterator { #list: NestedInteger[]; #iterator: Generator<number | null, void, unknown>; #done = false; #value = 0;
constructor(nestedList: NestedInteger[]) { this.#list = nestedList; const iterator = NestedIntegerIterator(nestedList); this.#iterator = iterator; this.#update_result(); }
#update_result() { const iterator = this.#iterator; const result = iterator.next(); const { done, value } = result;
this.#done = Boolean(done); this.#value = Number(value); }
hasNext(): boolean { if (this.#list.length === 0) return false;
return !this.#done; }
next(): number { if (this.#list.length === 0) return 0; const value = this.#value; this.#update_result();
return value; }}
export default NestedIterator;
masx200_leetcode_test

Version Info

Tagged at
a year ago