C++ Exercises: Compute the sum of two given binary strings
C++ Math: Exercise-22 with Solution
Write a C++ program to compute the sum of a pair of binary strings. Binary strings will be returned, and input strings shouldn't be blank or contain just 1 or 0 characters.
Sample Input: bstr1 = "10"
bstr2 = "1"
Sample Output: 10 + 1 = 11
Sample Input: bstr1 = "1100"
bstr2 = "1010"
Sample Output: 1100 + 1010 = 10110
Sample Solution:
C++ Code :
#include <iostream>
using namespace std;
// Function to add two binary strings
string binary_add(string bstr1, string bstr2) {
// Determine the size of the result string
int size = max(bstr1.size(), bstr2.size());
int temp = 0;
// Initialize an empty string to store the result
string result_str = "";
// Loop through each position of the binary strings and perform addition
for (auto i = 0; i < size; ++i) {
// Extract individual digits of binary strings
int digit1 = (i + 1 <= bstr1.size()) ? bstr1[bstr1.size() - 1 - i] - '0' : 0;
int digit2 = (i + 1 <= bstr2.size()) ? bstr2[bstr2.size() - 1 - i] - '0' : 0;
// Calculate the sum of digits along with the carry
int number = (digit1 + digit2 + temp);
temp = number / 2;
// Append the sum digit to the result string
result_str = to_string(number % 2) + result_str;
}
// If there's a remaining carry, add it to the result
if (temp > 0) {
result_str = to_string(temp) + result_str;
}
return result_str; // Return the final result
}
// Main function to test binary_add function
int main() {
string bstr1 = "10";
string bstr2 = "1";
cout << "\n" << bstr1 << " + " << bstr2 << " = " << binary_add(bstr1, bstr2) << endl;
bstr1 = "1100";
bstr2 = "1010";
cout << "\n" << bstr1 << " + " << bstr2 << " = " << binary_add(bstr1, bstr2) << endl;
bstr1 = "10";
bstr2 = "10";
cout << "\n" << bstr1 << " + " << bstr2 << " = " << binary_add(bstr1, bstr2) << endl;
return 0;
}
Sample Output:
10 + 1 = 11 1100 + 1010 = 10110 10 + 10 = 100
Flowchart:
C++ Code Editor:
Contribute your code and comments through Disqus.
Previous: Write a C++ program to check if a given string is a decimal number or not.
Next: Write a C++ program to compute square root of a given non-negative integer.What is the difficulty level of this exercise?
It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.
https://www.w3resource.com/cpp-exercises/math/cpp-math-exercise-22.php
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics