题目描述
输入两个整数,求这两个整数的和是多少。
样例
3 4
7
$10$
算法1
(暴力枚举) $O(1)$
C++ 代码
#include <bits/stdc++.h>
using namespace std;
int a,b;
int main()
{
cin>>a>>b;
cout<<a+b;
return 0;
}
算法2
(高精度) $O(n)$
就是高精++
时间复杂度o(n)
C++ 代码
#include <iostream>
#include <vector>
using namespace std;
const int N=1e6+10;
//C=A+B
vector<int> add(vector<int> &A, vector<int> &B)
{
vector<int> C;
int t = 0;
for(int i = 0;i < A.size() || i < B.size(); i ++ )
{
if(i < A.size()) t += A[i];
if(i < B.size()) t += B[i];
C.push_back(t%10);
t/=10;
}
if(t) C.push_back(1);
return C;
}
int main()
{
string a,b;
vector<int> A,B;
cin >> a >> b;
for(int i = a.size() - 1;i >= 0;i -- ) A.push_back(a[i] - '0');
for(int i = b.size() - 1;i >= 0;i -- ) B.push_back(b[i] - '0');
vector<int> C = add(A,B);
for(int i=C.size()-1;i>=0;i--) cout<<C[i];
return 0;
}