조회 수 13488 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

빅넘버 연산 (Big number)

기본 자료형(int)이 표현할 수 있는 숫자보다 더 큰 숫자를 덧셈하는 예제..

문자열로 입력 받고 모두 문자열 자체를 덧셈 매커니즘에 적용함.

(gets 함수 warning 으로 fgets 함수로 대체 사용~)

#include <stdio.h>
#include <string.h>

int main(){
    static char s1[200],s2[200];
    int max, sum, t, i, j, k, size_1, size_2;
    static int re[200],f1[200],f2[200];
    
    //버퍼오버플로우 취약점으로 gets -> fgets로 변경
    printf("First No : ");
    //gets(s1);
    fgets(s1, sizeof(s1)-1, stdin);
    
    printf("Second No : ");
    //gets(s2);
    fgets(s2, sizeof(s2)-1, stdin);
    
    //fgets는 엔터까지 입력받으므로 1을 뺀다.
    //size_1 = strlen(s1);
    //size_2 = strlen(s2);
    size_1 = strlen(s1)-1;
    size_2 = strlen(s2)-1;

    printf("size 1=%d, 2=%d\n", size_1, size_2);
    
    max=size_1>size_2?size_1-1:size_2-1;
    
    k=0;    
    for(i=size_1-1;i>=0;i--){
        f1[k]=s1[i]-'0';
        k++;
    }
    
    k=0;
    for(i=size_2-1;i>=0;i--){
        f2[k]=s2[i]-'0';
        k++;
    }
    
    for(i=0;i<=max;i++){
        sum=f1[i]+f2[i];
        if(sum>9){
            re[i]+=sum%10;
            re[i+1]+=sum/10;
        }else re[i]+=sum;
    }
    
    for(i=max;i>=0;i--) printf("%d",re[i]);
    printf("\n");

    return 0;
}

?
  • ?
    broDuck 2016.01.31 14:02
    999 + 999 와 같은 carry가 붙는 같은 자리수 연산에서는 예외처리가 되어있지 않네요. max값을 조정하는 코드가 들어가야 할 것 같아요~

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
661 Develop [c] 소수 구하기 #2 (입력한 숫자가 소수인지 판별하기..) hooni 2013.04.23 11013
660 Develop 다양한 방법으로 아주 큰 수(Big Number) 계산.. ㅋㅋ hooni 2013.04.23 8414
» Develop [c] 기본 자료형(int)이 표현할 수 없는 큰 수(Big number)를 덧셈하는 코드. 1 hooni 2013.04.23 13488
658 Develop [c++] MFC 모든 헤더와 라이브러리 설명 | [교류]Programming hooni 2013.04.23 7465
657 Develop [vb] 64bit RSA 프로그램 소스 ㅋㅋ file hooni 2013.04.23 8237
656 Develop 참고하고 지울 자료.. 집에서 바야지.. ㅋㅋ file hooni 2013.04.23 12182
655 Develop [c#] 본현이형 논문 자료 (HIDS)ㅋㅋ file hooni 2013.04.23 8200
654 Develop [c++] mfc 조건별 파일 검색 프로그램 소스 ㅋㅋ 19 file hooni 2013.04.23 11441
653 Develop [c++] mfc 간단한 파일 입출력 예제 hooni 2013.04.23 13563
652 Develop [c++] mfc 파일 한줄씩 읽기.. ㅋㅋ hooni 2013.04.23 28651
651 Develop [c++][mfc] 파일 입출력 샘플 (한줄씩 읽어서 다른 파일에 쓰기) hooni 2013.04.23 15060
650 Develop [c++] mfc 이용한 기본적인 형변환 예제 hooni 2013.04.23 11508
649 Develop [c++] mfc 이용한 트레이아이콘(TrayIcon) 클래스 예제 프로젝트 file hooni 2013.04.23 8833
648 Develop [c++] mfc이용한 트레이아이콘(TrayIcon) 클래스 예제 프로젝트 file hooni 2013.04.23 9277
647 Develop [c++] winsock을 이용한 서버,클라이언트와 ssl서버,클라이언트 file hooni 2013.04.23 7643
646 Develop [c] 문자열 str_shift 예제.. file hooni 2013.04.23 6862
Board Pagination Prev 1 ... 31 32 33 34 35 ... 74 Next
/ 74