menghitung akar persamaan kuadrat C++

menghitung akar persamaan kuadrat C++ (kasus 2 bab 4 diktat alpro)




Kasus 2 " Menentukan Jenis Akar Persamaan Kuadrat "

Algoritma :
    - mendeklarasikan variabel untuk koefisien pangkat 1, koefisien pangkat 2, koefisien pangkat 0, deskriminan
    - di inputkan koefisien pangkat 1, koefisien pangkat 2, koefisien pangkat 3
    - Menampilkan hasil jenis akar imajiner, rasional

Deklarasi :
    - koefisien pangkat 1, 2, 3 : interger
    - diskriminan : float
   
Deskripsi :
    Read (koefisien pangkat 1, koefisien pangkat 2, koefisien pangkat 3)
    deskriminan <- b^2-4*A*C
    if (A = 0) then write (‘Bukan Persamaan Kuadrat’)
    else if disk > 0 then   
    x1 ( -B + sqrt (disk)/2*A
    x2 ( -B - sqrt(disk)/2*A
    else if disk = 0 then
    x1 ( -B/2*A
    x2 ( x1   
    else write (‘Akar imajiner’)
    end if
    write (x1,x2)
#include <iostream>
#include <math.h>
#include <conio.h>

using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop */

class Akar {
    friend ostream& operator<<(ostream&, Akar&);
    friend istream& operator>>(istream&, Akar&);
    public:
    Akar();
    int disk() { return B*B-4*A*C; }
    float akar1() {return (-B+sqrt(disk()))/(2*A); }
    float akar2() {return (-B-sqrt(disk()))/(2*A); }
    void hitung_akar();
    void cetak_disk() {
         cout << "diskriminan = " << disk() << endl; }
    void cetak_akar() {
        cout << "x1 = " << akar1() << endl;
        cout << "x2 = " << akar2() << endl;
    }
private:
    int A, B, C; // input
    float x1, x2; // akar 1 dan akar 2
};
ostream& operator<<(ostream& out, Akar& keluaran) {
    keluaran.cetak_disk();
    if (keluaran.disk() >= 0) keluaran.cetak_akar();
    else out << "Akar imajiner";
    return out;
}
istream& operator>>(istream& in, Akar& masukan) {
    cout << "Koefisien pangkat 2 : "; cin >> masukan.A;
    cout << "Koefisien pangkat 1 : "; cin >> masukan.B;
    cout << "Koefisien pangkat 0 : "; cin >> masukan.C;
return in;
}
Akar::Akar() {
    cout << "Menghitung akar persamaan kuadrat "<<endl<<endl;
}

void Akar::hitung_akar() {
    if (A == 0) {
    cout << "bukan pers. kuadrat.\n";
    cout << "Harga akar = " << -C/B; } else {
    if (disk() > 0) {
        x1 = akar1();
        x2 = akar2();
        }   
    else if (disk() == 0) {
        x1 = akar1();
        x2 = x1;
        }
    }   
}

int main(int argc, char** argv) {
    Akar kasus;
    cin >> kasus;
    kasus.hitung_akar();
    cout << kasus;
    return 0;
}
sedangkan untuk rator nya :






EmoticonEmoticon