Contents

?

단축키

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
번호 분류 제목 글쓴이 날짜 조회 수
841 Develop 프로그램 문서 관리 (Doxygen) hooni 2013.04.23 16391
840 Develop 프로그래밍에서 foo, bar 함수의 유래 file hooni 2013.06.25 21265
839 Develop 프로그래밍 소스 관련 사이트.. hooni 2013.04.23 16486
838 Develop 페이팔에서 돈 찾기 (Paypal withdraw) file hooni 2014.02.20 11387
837 Develop 캘리포니아 운전면허 족보 file hooni 2017.06.12 744
836 Develop 최근 논문 자료 (2011/01/03, 만현형한테 보낸거..) secret hooni 2013.04.23 10366
835 Develop 참고하고 지울 자료.. 집에서 바야지.. ㅋㅋ file hooni 2013.04.23 12129
834 Develop 정리할 자료. file hooni 2015.07.02 679
833 Develop 자주 쓰는 Docker 명령어 alias hooni 2020.01.10 269819
832 Develop 이어서 작업할 내용~ secret hooni 2013.11.21 0
831 Develop 웹페이지 성능 테스트 툴 설명 hooni 2013.04.23 27449
830 Develop 알고리즘 성능분석 file hooni 2014.06.24 2974
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 71 Next
/ 71