• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Program na obliczenie wzoru kwadratowego-prosze o sprawdzenie

Object Storage Arubacloud
0 głosów
91 wizyt
pytanie zadane 29 marca 2020 w C i C++ przez Miszka255 Początkujący (280 p.)

Witam, prosze o sprawdzenie kodu na program który oblicza wzór kwadratowy. Ucze sie dopiero programować wiec proszę o wyrozumiałość

#include <iostream>
#include <math.h>
using namespace std;
int main() {

int a;
int b;
int c;
int delta;
int w1;
int w2;
int x1;
int x2;

    cout << "Podaj a: " << endl;
    for(int i = 0 ; i < 10 ; i++) {
        cin >> i;
        if (i != 0) {
            a = i;
            break;

        }
        else {
            cout << "Niepoprawna wartość: " << endl;
            cout << "Niepoprawna wartość: " << endl;
        }
    }
    cout << "Podaj b: " << endl;
    for(int i = 0 ; i < 10 ; i++){
        cin >> i;
        if (i != 0) {
            b = i;
            break;
        } else {
            cout << "Nieprawidłowa wartość." << endl;
            cout << "Podaj poprawną wartość: " << endl;
        }
    }
    cout << "Podaj wartość dla c: " << endl;
    for(int i = 0 ; i < 10 ; i++) {
        cin >> i;
        if (i != 0) {
            c = i;
            break;
        } else {
            cout << "Nieprawidłowa wartość." << endl;
            cout << "Podaj prawidłową wartość: " << endl;
        }
    }
    delta = pow(b,2)-4*a*c;
    cout << "Delta:  " << delta << endl << endl;
    w1 = -b/(2*a) ;
    w2 = -delta/(4*a);
    cout << "Współrzędne wierzchołka x: " << w1 << endl;
    cout << "Współrzędne wierzchołka y: " << w2 << endl << endl;
    if(delta >= 0){
        if(delta > 0){
            x1 = (-b-sqrt(delta))/(2*a);
            x2 = (-b+sqrt(delta))/(2*a);
            cout << "x = " << x1 << endl << "lub" << endl << "x jest równy: " << x2 << endl;
        }
        else{
            cout << "x =  " << w1 << endl;
        }
    }
    else{
        cout << "Nie ma miejsc zerowych: " << endl;
    }
    return 0;
}

 

1 odpowiedź

+1 głos
odpowiedź 29 marca 2020 przez DragonCoder Nałogowiec (36,500 p.)

so, pewnie zrobilbym cos takiego:

#include <iostream>
#include <cmath>
#include <iomanip>

int main()
{

    double a;
    do {
        std::cin >> a;
        if (a == 0) {
            std::cout << "Zla wartosc";
        }
    } while (a == 0);
    std::cout << "Podaj b: ";
    double b;
    std::cin >> b;
    std::cout << "Podaj wartość dla c: ";
    double c;
    std::cin >> c;
    double dyskriminanta = pow (b,2) - (4*a*c);

    if (dyskriminanta >= 0) {
        double x1 = 0 - (b/2*a) + sqrt (pow (b,2) - 4*a*c)/(4*pow(a,2));
        double x2 = 0 - (b/2*a) - sqrt (pow (b,2) - 4*a*c)/(4*pow(a,2));
        
        std::cout << "x1 = " << std::setprecision(5) << x1 << "\n";
        std::cout << "x2 = " << std::setprecision(5) << x2 << "\n";

        std::cout << "P11 ( " << x1 << " | 0) \n";
        std::cout << "P2 ( " << x2 << "| 0) \n";
    } else {
        std::cout << "Brak miejsc zerowch";
    }
    return 0;
}

ale objasnienia i ewentualne poprawki:

1. zamiast math.h uzyj cmath

2. using namespace std; nie uzywaj, pisz po prostu std:: jak ja

3. zobacz na uklad yzmiennych w moim kodzie, ich inicjalizacja i deklaracja odbywa sie w miejscu, gdzie sa potrzebne, a nie na samej gorze

4. miejsca zerowe moga miec przecinek, przez co typ int nie ma sensu

5. petle for zmienilem na do while, ktora powtarza sie, az ktos nie wpisze nic innego niz zero

6. pozostale 2 petle nie maja sensu, bo funkcja moze miec postac x^2, wiec ma rozwiazanie. Raczej a nie moze byc rowne 0, bo wtedy nie ma mowy o funkcji kwadratowej a liniowej

7. nazwy zmiennych, co prawda ja zostawilem tak jak sa, ale warto nazywamy je po angielsku i daje im nazwe taka, zeby miala sens i znaczenie

8. Współrzędne wierzchołka x: jezeli mowi sie o wspolrzednych to ma sie zazwyczaj na mysli 2 punkty, wiec to troch bez sensu, ale to nie dotyczy kodu

9.

      break;
 
        }
        else {
            cout << "Niepoprawna wartość: " << endl;
            cout << "Niepoprawna wartość: " << endl;
        }
    }
    cout << "Podaj b: " << endl;
    for(int i = 0 ; i < 10 ; i++){
        cin >> i;
        if (i != 0) {
            b = i;
            break;
        } else {
            cout << "Nieprawidłowa wartość." << endl;
            cout << "Podaj poprawną wartość: " << endl;
        }

trzymaj sie jednego code style, czyli jesli zrobic } else czy cos innego, to rob to wszedzie.

To chyba tyle z mojej strony

Podobne pytania

–5 głosów
1 odpowiedź 521 wizyt
0 głosów
1 odpowiedź 223 wizyt
0 głosów
3 odpowiedzi 672 wizyt
pytanie zadane 6 października 2021 w C i C++ przez polandonion Mądrala (7,040 p.)

92,570 zapytań

141,422 odpowiedzi

319,643 komentarzy

61,958 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...