이전에 C#으로 SICP에 나온 Infinite Streams을 구현 해본적이 있는데
이번에는 C++로 구현 해보았습니다. 실제로 이런 Lazy한 기법들이 사용될 곳이 있을지는 생각을 더 해봐야 겠지만 일단은 공부 한다는 차원에서 .... 해볼만한 것 같습니다.
만든 Infinite를 사용하는 main코드는 아래와 같은 모양으로 생겼습니다.
(wcout를 쓰기 위해서 그냥 tchar를 사용하지 않았습니다.)
bool isEven(int i) { return (i%2 == 0); }
int wmain(int argc, wchar_t* argv[])
{fibs()->filter(isEven)->take(10)->out(std::wcout);
return 0;}
눈치가 빠르신 분들은 벌써 아셨겠지만 코드는...
피보나치수열(fibs)를 얻어서, 이 중 짝수만 걸러내서(filter) 그 중에서 제일 앞에 10개만(take) 출력(out)하겠다는 코드 입니다. 물론 C++에서 저렇게 exception처리도 없이 ->연산자를 중복해서 사용하는 것은 좋지 않지만 실제로 사용하는 코드가 아니니 이해해 주시기 바랍니다.
아무튼 그래서 피보나치 수열 중에서 짝수 중 앞에 10개는 아래와 같습니다.
위 코드가 아래와 같은 결과를 나오게 만들면 되겠지요?
시간 있으신 분들은 제가 한 방법 말고 다른 방법으로 구현 해보셔도 재미있을 것 같네요 ^^
2
8
34
144
610
2584
10946
46368
196418
832040
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
소스보기 :
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
소스를 직접 까보기 귀찮은신 분들을 위해서..
주요 부분 소스를 붙입니다.. (메모리는.. shared_ptr을 썼다가 지저분해서 뺐습니다.)
class fibo_stream : public make_stream<int>
{public:fibo_stream()
: make_stream<int>(1, 1) {}virtual IStream<int>* _tail()
{IStream<int>* super_tail = make_stream<int>::_tail();
return new fibo_stream(super_tail->head(),
head()+super_tail->head());
}
protected:fibo_stream(int head, int tail)
: make_stream<int>(head, tail) {}};
IStream<int>* fibs() { return new fibo_stream(); }
피보나치 수열 스트림의 포인트는 항상 두개의 값만 계산해 놓는다는 겁니다. 즉, 미리 앞서나가지 않는 것 입니다.
덧)
아래 wafe님의 지적을 받아서 표준이 아닌 문법을 고쳐서 g++에서도 컴파일 될 수 있도록 했습니다.
'공부 하기' 카테고리의 다른 글
| Infinite Streams in Python (2) | 2008/02/01 |
|---|---|
| Infinite Streams in C++ (2) | 2008/01/21 |
| Javascript에서 Scope (4) - Element Object에서 this (8) | 2008/01/07 |
| Javascript에서 Scope (3) - this, prototype, new (4) | 2008/01/01 |
| Javascript에서 Scope (2) - 응용 (0) | 2007/12/31 |
| Javascript에서 Scope (1) - 기본 (6) | 2007/12/29 |
| C# 3.0으로 알아 본(?) 컴퓨터 프로그램의 구조와 해석 (0) | 2007/12/23 |
istream.cpp
