메뉴 건너뛰기

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;
}

?

  1. Programming 게시판 관련

    Date2014.11.01 CategoryTool/etc ByMoA Views1709
    read more
  2. 후킹 링크

    Date2013.07.28 CategoryAPI/MFC ByMoA Views415
    Read More
  3. 화면 캡쳐 소스

    Date2014.01.14 CategoryPython ByMoA Views973
    Read More
  4. 프린터 출력하기

    Date2013.10.16 CategoryAPI/MFC ByMoA Views3437
    Read More
  5. 프로세스 - 생성과 종료 그리고 이것 저것

    Date2011.10.12 CategoryAPI/MFC By너울 Views1834
    Read More
  6. 프로그램 배포용으로 만드는 과정

    Date2012.01.20 CategoryAPI/MFC By너울 Views488
    Read More
  7. 프로그래밍 관련 사이트

    Date2012.08.02 CategorySite ByMoA Views255
    Read More
  8. 파일 입출력

    Date2013.07.28 CategoryC/C++ ByMoA Views487
    Read More
  9. 파이썬에서 C모듈 사용하기

    Date2014.02.10 CategoryPython ByMoA Views1919
    Read More
  10. 파이썬 머신러닝 무료 강의 (7시간)

    Date2022.07.06 CategoryDeeplearning ByOBG Views97
    Read More
  11. 특정 자료형의 데이터를 binary(hex값, 2진수값)으로 변환

    Date2012.11.15 CategorySite ByNaya Views558
    Read More
  12. 텍스트 에디터 Sublime Text 2

    Date2012.03.30 CategoryTool/etc By너울 Views505
    Read More
  13. 태스크 대화상자 (Task Dialog)

    Date2013.10.22 CategoryAPI/MFC ByMoA Views436
    Read More
  14. 큰 수 구하기 알고리즘

    Date2012.08.02 CategoryAlgorithm ByNaya Views657
    Read More
  15. 쿠버네티스 클러스터

    Date2022.11.11 CategoryTool/etc ByOBG Views112
    Read More
  16. 코드 실행 시간 계산

    Date2012.08.02 CategoryC/C++ ByNaya Views297
    Read More
  17. 코드 실행 시간 계산

    Date2012.09.27 CategoryC/C++ ByNaya Views492
    Read More
  18. 컨텍스트 스위칭 (Context Switching)

    Date2013.07.28 CategoryTool/etc ByMoA Views1039
    Read More
  19. 카카오톡 웹버전 만들기

    Date2022.11.09 CategoryWeb ByOBG Views192
    Read More
  20. 추천(Recommendation) 시스템 - 알고리즘 Trend 정리

    Date2021.08.03 CategoryDeeplearning ByOBG Views134
    Read More
  21. 추천 시스템

    Date2023.03.30 CategoryDeeplearning ByOBG Views120
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15
위로