메뉴 건너뛰기

OBG

Programming

Algorithm
2012.08.02 21:06

큰 수 구하기 알고리즘

조회 수 658 추천 수 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;
}

?

  1. Programming 게시판 관련

  2. 후킹 링크

  3. 화면 캡쳐 소스

  4. 프린터 출력하기

  5. 프로세스 - 생성과 종료 그리고 이것 저것

  6. 프로그램 배포용으로 만드는 과정

  7. 프로그래밍 관련 사이트

  8. 파일 입출력

  9. 파이썬에서 C모듈 사용하기

  10. 파이썬 머신러닝 무료 강의 (7시간)

  11. 특정 자료형의 데이터를 binary(hex값, 2진수값)으로 변환

  12. 텍스트 에디터 Sublime Text 2

  13. 태스크 대화상자 (Task Dialog)

  14. 큰 수 구하기 알고리즘

  15. 쿠버네티스 클러스터

  16. 코드 실행 시간 계산

  17. 코드 실행 시간 계산

  18. 컨텍스트 스위칭 (Context Switching)

  19. 카카오톡 웹버전 만들기

  20. 추천(Recommendation) 시스템 - 알고리즘 Trend 정리

  21. 추천 시스템

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15
위로