개미 수열을 푸는 10가지 방법
무료!
멤버십 적용
$9.99
권장 가격

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

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

도서 소개

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

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

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

저자 소개

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일 이내클릭 두 번으로 모든 Leanpub 구매에 대해 100% 환불을 받으실 수 있습니다.

기술적으로는 책이나 코스 파일을 이미 받으셨기 때문에 저희에게는 위험이 있습니다. 하지만 저희는 저희의 제품과 서비스, 그리고 저자와 독자분들을 매우 신뢰하기 때문에 저희가 판매하는 모든 것에 대해 기꺼이 전액 환불을 보장해 드립니다.

어떤 것이 좋은지는 직접 시도해보아야만 알 수 있습니다. 100% 환불 보장이 있기 때문에 시도해 보는 데 전혀 위험이 없습니다!

그러니 장바구니에 추가하기 버튼을 클릭하지 않을 이유가 없겠죠?

전체 약관 보기...

10달러 구매에 8달러, 20달러 구매에 16달러를 받으세요

7.99달러 이상의 구매에 대해 80%의 로열티를 지급하며, 0.99달러에서 7.98달러 사이의 구매에 대해서는 50센트의 고정 수수료를 제외한 80%의 로열티를 지급합니다. 10달러 판매에서 8달러를, 20달러 판매에서 16달러를 받으실 수 있습니다. 따라서 만약 귀하의 책이 20달러에 환불되지 않은 상태로 5000부가 판매된다면, 80,000달러를 받으실 수 있습니다.

(네, 일부 작가들은 이미 Leanpub에서 그 이상을 벌었습니다.)

실제로 작가들은 Leanpub에서 글을 쓰고, 출판하고, 판매하여1,400만 달러 이상을 벌었습니다.

Leanpub에서 집필하는 방법 자세히 알아보기

무료 업데이트. DRM 무료.

Leanpub 책을 구매하시면 저자가 책을 업데이트하는 한 무료로 업데이트를 받으실 수 있습니다! 많은 저자들이 책을 쓰는 과정에서 Leanpub을 통해 출간하고 있습니다. 모든 독자는 구매 시기나 지불 금액(무료 포함)에 관계없이 무료 업데이트를 받습니다.

대부분의 Leanpub 책은 PDF(컴퓨터용)와 EPUB(휴대폰, 태블릿, 킨들용) 형식으로 제공됩니다. 책에서 제공되는 형식은 이 페이지의 오른쪽 상단에서 확인하실 수 있습니다.

마지막으로, Leanpub 책에는 DRM 복사 방지 제한이 전혀 없어 지원되는 모든 기기에서 쉽게 읽으실 수 있습니다.

Leanpub의 전자책 형식과 읽을 수 있는 곳에 대해 자세히 알아보기

Leanpub에서 저술하고 출판하세요

Leanpub을 사용하면 진행 중인 작업과 완성된 전자책 및 온라인 강좌를 쉽게 저술, 출판하고 판매할 수 있습니다!

Leanpub은 진지한 저자들을 위한 강력한 플랫폼으로, 간단하고 우아한 저술 및 출판 워크플로우와 진행 중인 전자책 판매에 중점을 둔 스토어를 결합했습니다.

Leanpub은 저자들을 위한 마법 같은 타자기입니다: 일반 텍스트로 작성하기만 하면 전자책 출판을 위해 버튼 하나만 클릭하면 됩니다. (또는 자신만의 방식으로 전자책을 제작하는 경우, 직접 PDF나 EPUB 파일을 업로드하여 원클릭으로 출판할 수도 있습니다!) 정말 이렇게 쉽습니다.

Leanpub에서 글쓰기에 대해 더 알아보기