HDU 1047 Integer Inquiry 大数相加 string解法
发布时间:2020-12-14 03:04:00 所属栏目:大数据 来源:网络整理
导读:本题就是大数相加,题目都不用看了。 不过注意的就是HDU的肯爹输出,好几次presentation error了。 还有个特殊情况,就是会有空数据的输入case。 #include stdio.h#include vector#include string.h#include algorithm#include iostream#include string#incl
本题就是大数相加,题目都不用看了。 不过注意的就是HDU的肯爹输出,好几次presentation error了。 还有个特殊情况,就是会有空数据的输入case。 #include <stdio.h> #include <vector> #include <string.h> #include <algorithm> #include <iostream> #include <string> #include <limits.h> #include <stack> #include <queue> #include <set> #include <map> using namespace std; void plusABtoA(string &a,string &b) { string c; int n = (int)a.size(),m = (int)b.size(),carry = 0; for (int i = n-1,j = m-1; i >= 0 || j >= 0 || carry; i--,j--) { int an = i>=0? a[i]-'0' : 0; int bn = j>=0? b[j]-'0' : 0; carry = an+bn+carry; c += char(carry%10 + '0'); carry /= 10; } reverse(c.begin(),c.end()); a = c; } int main() { int N; string a,b; cin>>N; while (N--) { cin>>a; if (a == "0")//注意特殊情况 { cout<<a<<endl; if (N) cout<<endl;//注意肯爹输出<span style="white-space:pre"> </span> continue; } while (cin>>b && b != "0") { plusABtoA(a,b); } cout<<a<<endl; if (N) cout<<endl;//注意肯爹输出 } return 0; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |