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 bringtEs 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 1printf("----------------- 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: 0101Gruß
-
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;