You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							27 lines
						
					
					
						
							861 B
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							27 lines
						
					
					
						
							861 B
						
					
					
				| export declare class HeadNode<T> { | |
|     next: LinkedListNode<T> | TailNode<T>; | |
|     constructor(); | |
| } | |
| export declare class TailNode<T> { | |
|     previous: LinkedListNode<T> | HeadNode<T>; | |
|     constructor(head: HeadNode<T>); | |
| } | |
| export declare class LinkedListNode<T> { | |
|     next: LinkedListNode<T> | TailNode<T> | null; | |
|     previous: LinkedListNode<T> | HeadNode<T> | null; | |
|     readonly item: T; | |
|     constructor(item: T); | |
|     detachSelf(): void; | |
|     attachAfter(node: LinkedListNode<T> | HeadNode<T>): void; | |
|     attachBefore(node: LinkedListNode<T> | TailNode<T>): void; | |
| } | |
| export declare class LinkedList<T> { | |
|     head: HeadNode<T>; | |
|     tail: TailNode<T>; | |
|     constructor(); | |
|     add(item: T): LinkedListNode<T>; | |
|     getItems(): T[]; | |
|     forEach(callback: (item: T, node: LinkedListNode<T>) => void): void; | |
|     hasItems(): boolean; | |
|     getLastItem(): LinkedListNode<T>; | |
| }
 | |
| 
 |