컴공 일기275
게시글 주소: https://orbi.kr/00072352394

교수가 꽤 재미있는 과제를 냈습니다. 피버나치 수열의 1000번째 값을 구하고 싶은데, 보다시피 자리수만 따져 보더라도 200자리가 훌쩍 넘어갑니다. 파이썬은 고민할 필요가 없겠습니다만 C언어에서는 200자리가 넘어가는 정수형을 담을 수 있는 기본 자료형이 존재하지 않습니다. 기껏해야 long long일텐데, 이 마저도 200자리는 커버할 수 없지요.
물론, 라이브러리를 이용하면 이 정도 문제야 간단히 해결할 수 있습니다만
바보가 아닌 교수는 라이브러리를 사용하지 않고, 적합한 코딩을 통해 200자리를 담아낼 수 있는 코드를 작성하라고 하는 겁니다.
방법은 간단합니다. 그냥 합치는 거죠. 기본 타입으로는 200비트를 커버할 수 없으므로, char형 200사이즈 되는 배열 두 개를 만들고,
피버나치 점화식을 돌리면서 이 배열들을 업데이트해주면 됩니다. 기본 정수형이 200비트에 모자라서 생긴 일이니, 충분히 커버할 수 있는 array 자료구조를 이용하면 되는 겁니다.
#include <stdio.h>
#include <string.h>
#define N 209 //The 1000th Fibonacci number has 209 decimal digits.
void print_digits(char d[N])
{
int i = 0;
while(d[i] == 0) i++;
while(i<N)
{
printf("%d", d[i++]);
}
}
void add_digits(char aa[N], char bb[N])
{
int i = 0;
int carry = 0;
int j,s;
while(aa[i] == 0) i++;
for(j=N-1; j>=i-1; j--)
{
if( ( s = carry + aa[j] + bb[j]) > 9)
{
carry = 1;
bb[j] = s-10;
}
else
{
bb[j] = s;
carry = 0;
}
}
}
int main()
{
char aa[N] = {0};
char bb[N] = {0};
char tmp[N] = {0};
bb[N-1] = 1;
for(int i=2; i<=1000; i++)
{
memcpy(tmp, bb, sizeof(bb)); //save bb
add_digits(aa, bb); //update bb
memcpy(aa, tmp, sizeof(tmp)); //update aa
}
print_digits(bb);
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
대학만 높이고 아무과나 ㄱㄴ 언 확 사탐 94 92 2 70 69 면 어디까지 가눙함?
-
단치 960.3 0
단치 960.3정도 였으면 붙었나요?
-
그 특징이 드러나는게 재밌음
-
투과목중 2초 1
물2 생2 뭐가 낫나요?
-
우리 학교 선배가 보인다 ㅈㄴ 신기하네
-
막상 보면 짧은 거 같기도 하고
-
중대발표 3
-
으흐흐 난 새우탈곡기야
-
비타500 조공까지 바쳤는데 안주시네..
-
색 2
연 필 연 색 연 필 연 색
-
닉언 ㄴㄴ 10
ㄴㄴ
-
와 사람 진짜 없네 20
역시 3월은 개강의 달
-
나온지 3년된 문제가 아직도 화제
-
울컥울컥 4
-
언매 강사 0
언매 강사 골라주세요!
-
혹시 수학 상 하랑 확통이랑 크게 연관이 되어 있나요??
-
한완수 질문 0
한완수 독학하려고 샀는데 문제풀기 전에 앞에 개념할때 예시로 들어주는 문제들...
-
ㅈㄱㄴ
-
아웃풋 좋다는 말이 숫자로 나열된 자료는.. 예전 sk하이닉스 입사자 유출 사진...
-
무물보선넘질 9
심심
-
무물보 62
./
-
이거 모르면 수능 망합니다 (반드시 알아야 할 개념정리) 5
믿어본다 gpt
-
D-252 2
수학 원순열 유형4(35문제) 중복순열 유형1(8문제) 같은 것이 있는 순열...
-
qNv 15번 2
자겟읍니다.. 안풀라그랫는데
-
ㅇㅈ 4
이번엔 진짜임 ㄹㅇ 옯평
-
2학년인데 공부에 집중해서 후회없이 2학년 보내고 싶은데 아무래도 친구 한 둘쯤은...
-
설면접떨이 다 중대오기도 했고 뭔가 갭차이가 크게 안느껴졌는데 수능입결은...
-
외지주 노잼 0
나재犬 재미없어
-
ㅇㅈ 5
집까지 걸어가늦중..
-
절대오지마셈
-
인생의주인공이라 0
이정돈되어야주인공이지 라는걸알아버린순간 엑스트라로서의삶은 이미확정되어버린걸까
-
지인이 미술하다 문과 아무대학이나 노리고 재수중이라 진짜 완전 노베입니다ㅠ 수학은...
-
내가 버틸수있을까
-
힝 ㅠㅠㅠㅠ
-
난 8시인데.
-
메가환급 0
학생증 사본 이거 모바일 학생증으로도 대신 인증가능함??
-
슈진코와다이 0
왓 슈진코와다이
-
바키 ㅅㅂ 트럼프랑 또 만난 게 ㅈㄴ 웃기네 ㅋㅋㅋㅋ 1
이것 일본 국뽕을 넘어선 그 무언가임. 경지를 넘어섰음 ㅋㅋㅋㅋ
-
녹음기엔안담기네드르렁슨드르렁슨쿠르르렁슨하씨발걍비염은민폐가맞음씨발
-
잠이나 자자 2
오늘은 글렀다
-
아니 2학년되니까 여기저기 옮겨다녀야되서 아싸 양극화 심해져요ㅠㅠ
-
기하 특 4
강사 학생 모두가 버림
-
수인 만화 4
왜 현실엔 없음? 이세계 가고 싶다
-
수1 1권은 13-14번급이고 2권 수열은 가야 15번급 나오던데 이게맞나
-
투과목 2컷 정도 목표면 어느 과목이 제일 나을까요? 물1은 2년 정도 계속 해서...
-
목러 점심시간에 0
목동러셀 점심시간에 도대체 밥먹고 다들 어딜 그렇게 옷입고...
-
문학 시간 소요 0
세 복합지문 시간 어느정도 쓸까요 전 비문학보다 오래걸리는데
-
숭컴이 입결 더 낮음 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ
-
회전초밥 말고 진짜 비싼 초밥 먹어보고 싶다
-
일 어 나 라 5
와 님 오랜만
ㄷㄷ
빅 인티저 문제 맞나 이게
이야 이거 1학년 자료구조 과제였는데