#include <bits/stdc++.h>
using namespace std;
int main(){
//开始编写程序
string s1,s2,t;//s1 s2代表2个要运算的数
int a[250] = {0},b[250] = {0},r[250] = {0};
char f;//符号,判断正负的,正号不要输出,符号要
int len,i,j;
getline(cin,s1);
getline(cin,s2);
len = s1.length() > s2.length()?s1.length():s2.length();
//判断正负,s1长那么s1大,一样长的话,s1的字典码大,那么s1大
if(s1.length() > s2.length() || (s1.length() == s2.length() && s1 >= s2)) {
f = '+';
}else{
f = '-';
t = s1;//s1对应的整数<s2的话,要交换做减法
s1 = s2;
s2 = t;
}
//倒过来将字符串存入数组再运算,注意字符要转化为实际的整数
for(i = 0;i < s1.length();i++){
a[i] = s1[s1.length() - i - 1] - 48;
}
for(i = 0;i < s2.length();i++){
b[i] = s2[s2.length() - i - 1] - 48;
}
//a b数组按照较长的长度,逐位运算
for(i = 0;i < len;i++){
//看看要不要借位
if(a[i] < b[i]){
a[i] = a[i] + 10;//借1当10
a[i + 1]--;//向后借一位
}
r[i] = a[i] - b[i];
}
//倒过来从第一个非0开始输出r数组
while(r[len] == 0){
len--;//找到第一个非0的下标
if(len < 0){
break;
}
}
if(f == '-') cout<<f;//如果是负数,输出负号
for(i = len;i >= 0;i--) {
cout<<r[i];
}
if(len < 0){
cout<<0<<endl;
}
}
/**************************************************************
Problem: 1269
User: admin
Language: C++
Result: Accepted
Time:12 ms
Memory:2076 kb
****************************************************************/