개미 수열을 푸는 10가지 방법
무료입니다!
With Membership
$9.99
권장 가격

개미 수열을 푸는 10가지 방법

알아두면 피와 살이 될 프로그래밍 개념 10가지

책 소개

이 책은 심심풀이로 시작되었다. 하지만 어쩌다보니 2년에 걸쳐 갖가지 방법이 동원되었다. 단지 '개미 수열' 한 문제를 풀기위해 정규표현식, 이터레이터, 코루틴, CSP 등 다양한 프로그래밍 개념까지 적용되었다. 각 개념들이 왜 필요한지, 어떻게 동작하는지 두루 살펴본다.

개미 수열은 누구나 한번쯤 풀어봤을 법한 쉬운 문제다. 과연 그럴까? 개미 수열은 '읽고 말하기 수열(look-and-say sequence)'이라고도 알려져 있으며, 줄마다 30% 정도씩 길이가 늘어난다고 증명되었다. 기하급수적으로 커지기 때문에 대충 해서는 100번째 줄을 출력하기도 어렵다. 반면 Haskell 같은 언어에서는 큰 문제가 되지 않는다. 그 차이를 파고들어 Java나 JavaScript에서도 100번째 줄 혹은 백만번째 줄을 출력할 수 있게 프로그램을 고쳐나간다.

쉬운 문제를 통해 오래되었지만 여전히 유효한 개념들(코루틴(1958), 제너레이터(1975), CPS(1975), CSP(1978) 등)을 맛볼 수 있는 좋은 기회를 제공해 줄 것이다.

  • 이 책을 공유하기

  • Categories

    • Computers and Programming
  • 피드백

    You must own a copy of this Book to access the forums.

    작가들의 이메일

저자 소개

Jooyung Han
한주영

10년 정도 개발 팀을 옆에서 도와주는 일만 했다. 코치나 해결사 역할은 흥미롭기는 하지만 공허할 때가 많다. 다시 개발자로 돌아가려고 하는데 떠난 시간이 길어서 그런지 쉽지 않다. 스타워즈 팬이다. 에피소드 7을 시작으로 시리즈가 부활하고 있어서 기쁘다. 책상에 앉아 있느라 가족들에게 소홀한 때가 많지만 그래도 패밀리맨이고 싶다.

현재 육아휴직 중이다. -- 2016년 겨울

다시 타이틀에 개발자를 붙이게 되었다. 육아 휴직을 잘 마쳤고, 두 번의 이직을 했다. 스타워즈는 마지막 에피소드를 앞두고 있다. -- 2018년 겨울

목차

  • 머릿말
  • 소스코드
  • 1장 개미 수열 시작하기
    • 읽고 말하기 수열
    • Java #0 - forString
    • Haskell #0 - 리스트
    • Java #1 - ant()next() 분리
    • Wishful Thinking
  • 2장 정규표현식
    • 반복 문자열 찾기
    • JavaScript #0 - 정규표현식
    • Java #2 - 정규표현식
    • App-specific vs. General
  • 3장 리스트 처리
    • next()가 하는 일
    • Java #3 - 리스트 처리
    • 리스트 처리 함수들
    • 함수형 프로그래밍
  • 4장 이터레이터
    • 개미 수열의 특성
    • 이터레이터와 이터러블
    • 개미 수열과 이터레이터
    • JavaScript #1 - 이터레이터
    • 지연 리스트로서의 이터레이터
    • 이터레이터 구현 리뷰
  • 5장 제너레이터
    • JavaScript #2 - 제너레이터
    • Java #4 - 쓰레드를 이용한 제너레이터
    • 이터레이터/제너레이터 리뷰
    • 제너레이터 이해하기
  • 6장 코루틴
    • 코루틴 이해하기
    • Go의 고루틴과 채널
    • Go #0 - 채널과 고루틴
    • 코루틴과 개미 수열
    • C #0 - 코루틴
    • C #1 - 매크로 푸!
    • JavaScript #5 - 제너레이터 코루틴
    • JavaScript #6 - js-csp
    • 개미 수열 복잡도
    • 코루틴 구현 리뷰
  • 7장 CPS
    • JavaScript #7 - CPS
    • Java #5 - CPS
    • CPS 구현 리뷰
  • 8장 CSP와 인터프리터 패턴
    • Go의 동시성 요소들
    • CSP를 위한 미니 언어
    • 핑퐁 예제
    • Java #6 - CSP 개미 수열
    • CSP 미니 언어 인터프리터
    • CSP 인터프리터 리뷰
  • 9장 지연 리스트
    • Haskell의 리스트는 지연 리스트
    • 지연 리스트를 지원하는 언어들
    • Java #7 - 지연 리스트
    • Java #8 - 지연 리스트 일반화
    • 지연 리스트 리뷰
  • 10장 리액티브 스트림
    • 노드로 시작
    • 배압
    • 리액티브 스트림
    • Java로 옮겨보기
    • 정리
  • Notes

Leanpub의 60일 간 100%만족 보장

구매일로부터 60일안에 어떤 결제든 클릭 두번으로 전액 환불을 받을 수 있습니다.

전체 약관 확인하기

Do Well. Do Good.

작가들은 Leanpub을 통해 글을 쓰고 출판하고 판매하여$11,955,464의 수익을 올렸습니다. 80% 로열티의 수입을 만드는 동안 2천5백만 파운드의 이산화탄소를 절감 했으며 46,000 그루의 나무를 아꼈습니다.

Leanpub에서 글 쓰는 법 더 보기

무료 업데이트. DRM(디지털 저작권 관리)는 없습니다.

당신이 Leanpub의 책을 산다면, 작가가 책을 업데이트 하는 한 책에 대한 무료 업데이트를 받을 수 있습니다! 많은 작가들은 Leanpub을 작성 중인 책을 출판하기 위해 이용합니다. 모든 독자들은 책을 언제 구매하건, 얼마나 지불하였건(무료 구매도 포합됩니다) 관계없이 무료 업데이트를 받습니다.

대부분의 Leanpub에 있는 책들은 PDF(컴퓨터용), EPUB(핸드폰과 태블릿용) 그리고 MOBI(킨들용)으로 제공됩니다. 책이 지원하는 포맷은 이 페이지 우측 상단에서 확인 할 수 있습니다.

Leanpub의 책은 DRM 사본 보호 장치를 드디어 없앴습니다, 그래서 지원가능한 어떤 기기로든 쉽게 구매하신 책들을 읽을 수 있습니다.

Leanpub의 ebook 포맷과 어디서 읽을 수 있는지 더 보기

Leanpub에서 글 쓰고 출판하기

당신은 Leanpub을 이용해 쉽게 글을 쓰고 출판할 수 있고 책과 코스가 작성중이든 완성 되었든 판매할 수 있습니다! Leanpub은 진지한 작가들을 위해 쉽고 우아한 글쓰기와 출판 과정을 작성중인 전자책들에 집중하여 판매 하는 온라인 쇼핑몰과 결합한 강력한 플랫폼 입니다. Leanpub은 작가들에게 마법같은 타자기와도 같습니다. 단지 단순한 텍스트를 쓰고, 출판하기 위해 그냥 버튼만 누르세요. 그만큼이나 쉽다구요.

Leanpub에서 글 쓰는 법 더 보기