FRACTRAN

testwiki
둘러보기로 이동 검색으로 이동

틀:위키데이터 속성 추적 FRACTRAN은 수학자 존 호턴 콘웨이가 고안한 난해한 프로그래밍 언어이다. FRACTRAN 프로그램은 양의 분수들로 이루어진 하나의 목록의 형태이다. 이 프로그램은 다음의 규칙으로 자연수 입력값 n을 갱신하며 작동한다.

  1. 목록의 분수들 중에서 nf가 자연수인 가장 첫번째 분수가 f일 때, 입력값 nnf로 바꿔쓴다.
  2. 더 이상 nf가 자연수인 분수 f가 없을때까지 위 과정을 반복한 후, 프로그램을 정지한다.

간단한 FRACTRAN 프로그래밍 예제

FRACTRAN 프로그램은 괴델 넘버링을 사용해 입력값과 출력값을 하나의 소인수분해로 표현한다. 예를 들어 a=2, b=1, c=1 을 입력하면

22×31×51

와 같은 형태로 표현한다

덧셈 프로그램

a와 b를 입력하면 a+b를 출력하는 프로그램은 다음과 같다

(32)

이 프로그램은 다음 알고리즘을 따른다.

상태 행동
32 2의 지수>0 2의 지수에서 1을빼고

3의 지수에 1을 더한다

2의 지수 = 0 정지

a와 b를 입력하면 다음과 같은 소인수분해 2a3b가 입력된다, 이 프로그램은 다음과 같은 수열 2a13b+1, 2a23b+2...을 생성하다가, 결국에 3a+b 곧, a+b를 출력한다.

뺄셈 프로그램

a와 b를 입력하면 a-b를 출력하는 프로그램은 다음과 같다.

(16)


최댓값 구하기 프로그램

a와 b를 입력하면 a와 b중 더 큰 값을 출력하는 프로그램은 다음과 같다

(56,52,53)

소수 생성 프로그램

다음은 존 콘웨이가 제시한 소수 생성 프로그램이다.

(1791,7885,1951,2338,2933,7729,9523,7719,117,1113,1311,152,17,551)

n=2를 입력하면,이 프로그램은 다음과 같은 수열

2, 15, 825, 725, 1925, 2275, 425, 390, 330, 290, 770, ... 틀:OEIS

을 생성하다가, 2의 소수 거듭제곱을 포함한다.

22=4,23=8,25=32,27=128,211=2048,213=8192,217=131072,219=524288, 틀:OEIS

곱셈 프로그램

두 자연수 a,b를 입력했을 때, ab를 출력하는 프로그램은 다음과 같다.

(45533,1113,111,37,112,13)
FRACTRAN프로그램으로 3곱하기2을 계산하는 과정,a=3,b=2를 괴델 수 2332로 변환 후 입력하여, 괴델 수 56,곧 6을 출력한다.

피보나치 프로그램

피보나치 수열을 생성하는 프로그램은 다음과 같다.

(3391,1311,111,34399,1917,171,72,5187,31)


같이 보기

각주

틀:각주 틀:참고 자료 시작

틀:참고 자료 끝

외부 링크

틀:위키공용분류