From c2b57162a2f290e3cfa447c2d08eaa2e0a245c21 Mon Sep 17 00:00:00 2001 From: newt Date: Wed, 9 Oct 2024 18:02:43 +0100 Subject: [PATCH] feat(c++ squareForm): patch bugs - --- languages/c++/code/squareForm.cc | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/languages/c++/code/squareForm.cc b/languages/c++/code/squareForm.cc index 5df9893..6a39081 100644 --- a/languages/c++/code/squareForm.cc +++ b/languages/c++/code/squareForm.cc @@ -12,8 +12,8 @@ double power(double base, double exponent) { // Euclid algorithm int greatestCommonDivisor(int a, int b) { - int currentA = a; - int currentB = b; + int currentA = abs(a); + int currentB = abs(b); bool divisorFound = false; while (currentA != currentB) { @@ -45,7 +45,7 @@ std::string formatFraction(int numerator, int denominator) { // Format a double by cutting off as many trailing zeros as possible std::string formatDouble(double input) { - std::string output = std::to_string(input); + std::string output = std::to_string(abs(input)); int pointIndex = output.find_last_of('.'); int firstZeroIndex = output.find_last_not_of('0') + 1; @@ -87,6 +87,21 @@ std::string completeTheSquare(double a, double b, double c) { return output; } +int promptForInteger(std::string letter) { + std::cout << "Please input a value for " + letter + ": "; + + int input; + std::cin >> input; + + return input; +} + int main() { - std::cout << completeTheSquare(1, 2, 5); -} \ No newline at end of file + std::cout << "ax² + b^x + c^x -> a(x + p) + q\n"; + + int a = promptForInteger("a"); + int b = promptForInteger("b"); + int c = promptForInteger("c"); + + std::cout << completeTheSquare(a, b, c); +}