Programm -Dezimalzahl-zu-Benärzahl



  • Ich habe folgendes Programm geschrieben um eine Dezimalzahl in eine Binärzahl umzuwandeln:

    #include <iostream>
    #include <cstdio>
    using namespace std;

    int main()
    {
    int n = 0;
    int m = 0;
    int o = 1;
    int dezwert, bereich = 0; // Eingabewert, Ausgabewert
    int rest; // Rest einer fortgesetzten Division durch 2
    int binwert[] = {n};

    printf("----------------- Programm fuer Binaerumwandlung -----------------\n\n");
    printf("Geben Sie eine Dezimalzahl ein:\t");
    cin >> dezwert;
    cout << endl << endl;
    cout << "Der Binaerwert von " << dezwert << " = \t";

    //Berechnung der Stellen
    rest = dezwert;

    while(rest != 0)
    {
    rest = rest / 2;
    ++bereich;
    }

    n = bereich;
    m = n;

    //Berechnung des Binärwerts
    while (dezwert != 0)
    {
    if ((dezwert % 2) == 0)
    {
    binwert[n] = 0;
    }
    else
    {
    binwert[n] = 1;
    }

    --n;
    dezwert = dezwert / 2;
    }

    //Ausgabe des Binärwerts
    while(o <= m)
    {
    cout << binwert[o];
    ++o;
    }

    fflush(stdin);
    getchar();
    return 0;
    }

    🙂 Es funktioniert auch soweit, aber das Programm stürzt ganz am Ende immer ab und mein Compiler sagt dass die Variable binwert corupted ist. Warum???

    Vielen Dank!!

    Gruß
    Stefan



  • Schau dir mal deine Variable binwert an.
    Beim erstellen reservierst du nur Platz fuer einen Wert.
    Spaeter greifst du aber auf Bereich zu, die fuer binwert nicht reserviert worden sind. Ich schaetze, dass du Speicherzugriffsverletzungen dadurch bekommst, was dein Programm zum Absturz bringt 😃

    Es ist eine sehr umstaendliche Errechnung. Die Werte fuer 1 und 0 kann man auch
    in einem String zusammenfuegen. Aber das war ja nicht die Frage 🙄



  • #include <iostream>
    #include <cstdio>
    using namespace std;

    int main()
    {
    int dezwert, binwert = 0; // Eingabewert, Ausgabewert
    int rest; // Rest einer fortgesetzten Division durch 2
    int wertigkeit = 1; // Multiplikator für stellenrichtige Addition der
    // Teilumwandlungen; Werte 1, 10, 100, 1000, ...
    int stelle; // Platzhalter für binäre 0 oder 1

    printf("----------------- Programm fuer Binaerumwandlung -----------------\n\n");
    printf("Geben Sie eine Dezimalzahl ein:\t");
    cin >> dezwert;
    cout << endl << endl;
    cout << "Der Binaerwert von " << dezwert << " = \t";

    //Berechnung der Stellen

    while (dezwert != 0)
    {

    if((dezwert % 2) == 0)
    {
    stelle = 0;
    }
    else
    {
    stelle = 1;
    }

    cout << left << stelle;
    dezwert = dezwert / 2;

    }

    fflush(stdin);
    getchar();
    return 0;
    }
    🙂 So weit war ich auch schon. Aber der verdreht mir dann meine Ausgabe.
    D.h.

    Statt : Dez 10 = Bin = 1010
    gibt er aus: 0101

    Gruß



  • entweder mit string arbeiten, oder du reservierst fuer dein int-Array den Speicher zur Laufzeit mit new in der Groesse, wie du ihn brauchst. Aber ersteres
    tut es auch.

    #include <string>
    
    ...
    
    string output;
    
    ...
    
    while(dezwert != 0)
    {
    	if((dezwert % 2) == 0)
    	{
    		output = "0" + output;
    	}
    	else
    	{
    		output = "1" + output;
    	}
    
    	dezwert = dezwert / 2;
    }
    
    cout << output;
    

Anmelden zum Antworten