提交时间:2023-05-17 18:17:29
运行 ID: 17691
#include<bits/stdc++.h> using namespace std; struct bign{ int d[1000]; int len; bign(){ len = 0; memset(d,0,sizeof(d)); } }; bign change(char str[]){ bign a; int len=strlen(str); for(int i=0;i<strlen(str);i++){ a.d[a.len]=str[len-i-1]-'0'; a.len++; } return a; } void print(bign a){ for(int i=a.len-1;i>=0;i--){ cout<<a.d[i]; } } bign add(bign a,bign b){ bign c; int carry=0; for(int i=0;i<a.len||i<b.len;i++){ int temp=a.d[i]+b.d[i]+carry; c.d[i]=temp%10; c.len++; carry=temp/10; } if(carry>0){ c.d[c.len]=carry; c.len++; } while(c.d[c.len-1]==0&&c.len>1){ c.len--; } return c; } int main(){ char s1[100],s2[100]; cin>>s1; cin>>s2; bign a=change(s1); bign b=change(s2); print(add(a,b)); return 0; }