Develop
2013.04.23 15:37
[c] 기본 자료형(int)이 표현할 수 없는 큰 수(Big number)를 덧셈하는 코드.
조회 수 13457 댓글 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; }
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
333 | System/OS | [linux] 아파치설치/설정 | hooni | 2003.04.23 | 14492 |
332 | System/OS | [linux] 아파치설치/설정 - SSI(Server Side Include) | hooni | 2003.04.23 | 13207 |
331 | System/OS | [linux] 아파치설치/설정 - 사용인증 | hooni | 2003.04.23 | 15087 |
330 | System/OS | [linux] 아파치설치/설정 - 알리어싱(aliasing) | hooni | 2003.04.23 | 51370 |
329 | System/OS | [linux] 아파치설치/설정(CGI부분) | hooni | 2003.04.23 | 14569 |
328 | System/OS | [linux] 아파치설치/설정(모니터링) | hooni | 2003.04.23 | 14154 |
327 | System/OS | [linux] 우분투 APM + phpmyadmin 설치 | hooni | 2013.10.07 | 49328 |
326 | System/OS | [linux] 웹로그분석기(webalizer) 설치 & 팁 | hooni | 2003.04.23 | 14882 |
325 | System/OS | [linux] 이기종간의 파일 공유(Samba) | hooni | 2003.04.23 | 14901 |
324 | Develop | [linux] 임베디드 리눅스 (embedded linux) | hooni | 2013.04.23 | 7356 |
323 | System/OS | [linux] 종료와 종료코드 확인(환경변수에서) | hooni | 2003.04.23 | 15548 |
322 | System/OS | [linux] 처음 설치부터 APM 설치까지 (업데이트 할 것) | hooni | 2013.04.23 | 38271 |