Develop
2013.04.23 15:37
[c] 기본 자료형(int)이 표현할 수 없는 큰 수(Big number)를 덧셈하는 코드.
Views 13457 Comment 1
빅넘버 연산 (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; }
-
?
999 + 999 와 같은 carry가 붙는 같은 자리수 연산에서는 예외처리가 되어있지 않네요. max값을 조정하는 코드가 들어가야 할 것 같아요~
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
669 | Develop | [c++] 윈도우 API 정복 예제 | hooni | 2013.04.23 | 7609 |
668 | Develop | [c#] BFilter 툴바 소스 코드 ㅎㅎ | hooni | 2013.04.23 | 7610 |
667 | Develop | [c] OpenGL 관측점 이동 | hooni | 2003.04.23 | 7611 |
666 | Develop | [c++] winsock을 이용한 서버,클라이언트와 ssl서버,클라이언트 | hooni | 2013.04.23 | 7614 |
665 | Develop | [js] 비만 지수 측정(BMI) ㅎㅎ | hooni | 2013.04.23 | 7614 |
664 | Develop | [js] 자바스크립트와 정규표현식 메뉴얼 (chm 형식) | hooni | 2013.04.23 | 7616 |
663 | Develop | SVN 초간단 사용하기 | hooni | 2014.02.28 | 7621 |
662 | Develop | [js] 핫키(단축키) 구현방법 | hooni | 2003.04.23 | 7629 |
661 | Develop | [java] 파일 라인수 계산하는 프로그램 (하위 디렉토리까지..) | hooni | 2013.04.23 | 7646 |
660 | Develop | [php] 자바스크립트 개판 만들기.. | hooni | 2013.04.23 | 7651 |
659 | Develop | [c#]업글 뉴 툴바 개인적으로 만든거.. (new) ㅋㅋ | hooni | 2013.04.23 | 7651 |
658 | Develop | [c] 코드 최적화에 대해.. | hooni | 2013.04.23 | 7656 |