메뉴 건너뛰기

OBG

Programming

Algorithm
2012.08.02 21:06

큰 수 구하기 알고리즘

조회 수 657 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
http://funnism.com/34

참고 : 
http://gall.dcinside.com/list.php?id=internet_site&no=7410&page=2&bbs=


제가 직접 짠 큰 수 팩토리얼을 구하는 소스코드입니다. 최적화나 어떤 알고리즘을 쓴것은 아니고 막코딩입니다.
10000팩토리얼의 자리수가 3만자리정도 되기때문에 결과값이 저장될 벡터의 크기는 40000으로 잡았습니다. 
더 큰수의 팩토리얼을 구하려면 자리수를 늘려주면 됩니다.

하지만 초보자분들이나 안짜보신분들은 꼭 먼저 짜보시고, 성공하신 다음 소스코드를 참조하시기 바랍니다.
그것이 실력향상의 지름길이니까요...^^

#include <iostream>
#include <vector>
using namespace std;
 
int main()
{
    vector<int>* vecData = new vector<int>;
 
    int length = 40000; // 결과값의 자리수
 
    vecData->reserve(length);
    vecData->assign(length, -1);
    int n = 1000;
    int carry = 0;
 
    (*vecData)[0] = 1;
    int offset = 1;
    for(int i=2;i <= n;i++){
        for(int j=0;j < offset;j++){
            (*vecData)[j] = (*vecData)[j] * i + carry;
            carry = 0;
            if((*vecData)[j] > 9){
                if((*vecData)[j+1] == -1){
                    offset++;
                    (*vecData)[j+1] = 0;
                }
                carry = (*vecData)[j] / 10;
                (*vecData)[j] = (*vecData)[j] % 10;
            }
        }
    }
 
    for(int i=0;i < offset;i++){
        cout << (*vecData)[offset-i-1];
    }
 
    delete vecData;
    return 0;
}

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 1708
286 API/MFC 후킹 링크 MoA 2013.07.28 415
285 Python 화면 캡쳐 소스 MoA 2014.01.14 973
284 API/MFC 프린터 출력하기 MoA 2013.10.16 3430
283 API/MFC 프로세스 - 생성과 종료 그리고 이것 저것 너울 2011.10.12 1834
282 API/MFC 프로그램 배포용으로 만드는 과정 너울 2012.01.20 488
281 Site 프로그래밍 관련 사이트 MoA 2012.08.02 255
280 C/C++ 파일 입출력 MoA 2013.07.28 487
279 Python 파이썬에서 C모듈 사용하기 MoA 2014.02.10 1919
278 Deeplearning 파이썬 머신러닝 무료 강의 (7시간) OBG 2022.07.06 97
277 Site 특정 자료형의 데이터를 binary(hex값, 2진수값)으로 변환 Naya 2012.11.15 556
276 Tool/etc 텍스트 에디터 Sublime Text 2 너울 2012.03.30 505
275 API/MFC 태스크 대화상자 (Task Dialog) MoA 2013.10.22 435
» Algorithm 큰 수 구하기 알고리즘 Naya 2012.08.02 657
273 Tool/etc 쿠버네티스 클러스터 OBG 2022.11.11 112
272 C/C++ 코드 실행 시간 계산 Naya 2012.08.02 297
271 C/C++ 코드 실행 시간 계산 Naya 2012.09.27 492
270 Tool/etc 컨텍스트 스위칭 (Context Switching) MoA 2013.07.28 1039
269 Web 카카오톡 웹버전 만들기 OBG 2022.11.09 191
268 Deeplearning 추천(Recommendation) 시스템 - 알고리즘 Trend 정리 OBG 2021.08.03 134
267 Deeplearning 추천 시스템 OBG 2023.03.30 120
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15
위로