adding 2 large numbers using arrays c++

Here is my task: Write a program that inputs two positive integers of, at most, 20 digits and outputs the sum of the numbers. If the sum of the numbers has more than 20 digits, output the sum with an appropriate message. Your program must, at least, contain a function to read and store a number into an array and another function to output the sum of the numbers. (Hint: Read numbers as strings and store the digits of the number in the reverse order.)

Ive pretty much gotten things fixed, its just that my output is printing each index's sum rather than a whole number with multiple digits. Also, I tried to add code to deter the user from typing over 20 characters but I get an error regarding the string variable not being able to used in this statement: if (user_str1>20)

int read_strings(int arr1[], int arr2[])
{
string user_str1;
string user_str2;

cout << "enter a positive integer of, at most, 20 digits " << endl;
cin >> user_str1;

for (int ind2 = user_str1.length() - 1; ind2 >= 0; ind2--)
{
arr1[ind2] = static_cast<int>(user_str1[ind2]) - static_cast<int> ('0');
}

cout << "now enter a second number with the same conditions as the first " << endl;
cin >> user_str2;


for (int d = user_str2.length() - 1; d >= 0; d--)
{
arr2[d] = static_cast<int>(user_str2[d]) - static_cast<int>('0');
}
return user_str1.length();
}
void print_sum(int arr1[], int arr2[], int size)
{
string user_str1;
string user_str2;

int sum_arr[20];


int carry = 0;
for (int e = 0; e < size; e++)
{
if (arr1[e] + arr2[e] + carry > 9)
{
sum_arr[e] = arr1[e] + arr2[e] + carry;
sum_arr[e] = sum_arr[e] % 10;
carry = 1;
}
else
{
sum_arr[e] = arr1[e] + arr2[e] + carry;
carry = 0;
}
cout << "the sum of the two arrays is: " << sum_arr[e];
cout << endl;
}


}
int main(){

int arr1[20];
int arr2[20];
int size = read_strings(arr1, arr2);
print_sum(arr1, arr2, size);
return 0;

}
A suggestion, use separate functions for the addition and output.

Addition needs to progress starting from the least-significant digit to the most-significant, while output needs to start from the most significant digit. That's a fundamental incompatibility.
Thanks, but my assignment forces me to follow certain guidelines. Also, how can i get the output to print 1 single integer, rather than the sum at each index.
Thanks, but my assignment forces me to follow certain guidelines.
Nevertheless, the fundamental incompatibility I referred to remains. At the very least you should separate out the processing of the two activities, even if they need to be contained in a single function.

Actually, the original post states,
"Your program must, at least, contain a function to read and store a number into an array and another function to output the sum of the numbers."
It says you should use at least two functions, it doesn't prohibit the use of other functions (in fact I'd consider it almost invites their use).


Also, how can i get the output to print 1 single integer, rather than the sum at each index.
Remove the cout << endl; from inside the loop, and just put a single newline after the loop has ended.

By the way, the storing of the digits in your arrays here:
1
2
3
4
for (int ind2 = user_str1.length() - 1; ind2 >= 0; ind2--)
{
    arr1[ind2] = static_cast<int>(user_str1[ind2]) - static_cast<int> ('0');
}
has a problem, it should be reversing the order of the digits, but in fact they are still in the original order.
how is not reversing? could you explain...
how is not reversing? could you explain...

Well, the loop steps through the characters of the string user_str1 in reverse order. It starts from the last character and proceeds one at a time until it reaches the first character. That's ok.

But what about the array arr1 ? The loop uses the same subscript ind2 to access that array too, so it too is receiving the digits in reverse order, starting from the last, and ending at the first. All that achieves is in effect an identical copy (if we ignore the conversion from character to integer for a moment).

Consider this:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <iostream>
#include <string>

using namespace std;

int main()
{    
    char   b[10] = {0};
    string a = "Apple"; 
    
    for (int i = a.length() - 1; i >= 0; i--)
    {
        b[i] = a[i];
    }    
    
    cout << "a = " << a << '\n';
    cout << "b = " << b << '\n';
    
    char   c[10] = {0};    
    
    int index = 0;
    for (int i = a.length() - 1; i >= 0; i--)
    {
        c[index] = a[i];
        index++;
    }     
    
    cout << "c = " << c << '\n';    
    
} 


This is the output:
a = Apple
b = Apple
c = elppA
Last edited on
Topic archived. No new replies allowed.