Develop
2013.04.23 15:37
[c] 기본 자료형(int)이 표현할 수 없는 큰 수(Big number)를 덧셈하는 코드.
Views 13487 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 |
---|---|---|---|---|---|
673 | Develop | [coding] 공부해야 하는거 ㅋㅋ | hooni | 2017.06.27 | 0 |
672 | Develop | [css] z-index에 설정할 수 있는 최대값? | hooni | 2013.12.20 | 14807 |
671 | Develop | [css] 스크롤바 안생기게 | hooni | 2003.04.23 | 9918 |
670 | Develop | [css] 화면 스크롤 제어 ㅋㅋ | hooni | 2003.04.23 | 8706 |
669 | Develop | [c] 64bit 머신에서 inet_ntoa() 사용시 Segment fault 대처 방법법 | hooni | 2014.02.08 | 14262 |
668 | Develop | [c] AES 알고리즘 (암호화/복호화) | hooni | 2003.04.23 | 20146 |
667 | Develop | [c] alarm()함수 설명과 간단한 예제 | hooni | 2013.04.23 | 6706 |
666 | Develop | [c] CGI Library to C^^ | hooni | 2003.04.23 | 8439 |
665 | Develop | [c] C로 구현한 CGI - 계산기 (링크리스트, 스택, 이진트리) | hooni | 2003.04.23 | 28157 |
664 | Develop | [c] C로 구현한 CGI - 달력과 날짜계산기 | hooni | 2003.04.23 | 32493 |
663 | Develop | [c] C로 구현한 CGI - 방명록 | hooni | 2003.04.23 | 33511 |
662 | Develop | [C] C언어의 조건 연산자(Conditional Operator) | hooni | 2003.04.23 | 14284 |