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 | [js] Javascript로 만든 포트리스 (2010) 5 | hooni | 2017.03.03 | 2827 |
672 | Develop | [c#] 툴바 현재 욜심히 만들고 있는거.. 백업용.. ㅋㅋ | hooni | 2013.04.23 | 2852 |
671 | Develop | 알고리즘 성능 분석 기준 | hooni | 2014.06.24 | 2916 |
670 | Develop | [ios] XCode에서 Provisioning Profile 여러개 중복될 때 | hooni | 2014.06.26 | 2951 |
669 | Develop | [ios] Objective-C 프로퍼티의 ATOMIC / NONATOMIC 속성 | hooni | 2014.03.17 | 3051 |
668 | Develop | [js] Array.splice() 설명 | hooni | 2014.04.24 | 3064 |
667 | Develop | [ios] iOS 사운드 관련 프레임워크 | hooni | 2014.04.18 | 3080 |
666 | Develop | 알고리즘 성능분석 | hooni | 2014.06.24 | 3109 |
665 | Develop | [ios] 커스텀 폰트 사용하기 (Custom Fonts) | hooni | 2014.04.30 | 3193 |
664 | Develop | [php] Connect to Firebase Console in Laravel | hooni | 2018.05.09 | 3228 |
663 | Develop | [ios] CoreData 사용하기 (튜토리얼) | hooni | 2014.03.28 | 3239 |
662 | Develop | [c#] 툴바 소스.. 개인적으로 만드는거.. | hooni | 2013.04.23 | 3304 |