21 lines
No EOL
448 B
TypeScript
21 lines
No EOL
448 B
TypeScript
interface IList<A> {
|
|
map<B>(f: (t: A) => B): IList<B>;
|
|
}
|
|
|
|
class Nil<C> implements IList<C>{
|
|
map<D>(f: (t: C) => D): IList<D> {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
class Cons<T> implements IList<T>{
|
|
map<U>(f: (t: T) => U): IList<U> {
|
|
return this.foldRight(new Nil<U>(), (t, acc) => {
|
|
return new Cons<U>();
|
|
});
|
|
}
|
|
|
|
foldRight<E>(z: E, f: (t: T, acc: E) => E): E {
|
|
return null;
|
|
}
|
|
} |