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???
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
_________________ Der Vorteil in der Klugheit besteht darin, dass man sich dumm stellen kann.
(Code::Blocks 10.5, mingw32 gcc 4.4.1)
#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.
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.
Nächstes Thema anzeigen Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben. Sie können auf Beiträge in diesem Forum antworten. Sie können Ihre Beiträge in diesem Forum nicht bearbeiten. Sie können Ihre Beiträge in diesem Forum nicht löschen. Sie können an Umfragen in diesem Forum nicht mitmachen.
c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums
für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de
Werbekostenerstattung verdient werden kann.
Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info, www.c-sar.de, www.c-plusplus.net und www.baeckmann.de
enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt
(vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in
privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden.
Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere
übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.