Guten Tag Hat jemand ein C-programm da stehen, dass Zahlen von binär in dezimal und von dezimal in binär rechnet? Vielen Dank
Woran scheitert es denn bei der Selbst-Programmierung? So schwer ist das wirklich nicht. Ansonsten: Der Windows Taschenrechner kann wunderbar umrechnen.
Das ist mir klar, dass ich es mit dem Taschenrechner umrechnen kann, sollte aber ein Programm in C schreiben und mir fehlen die Lösungsansätze. Hat niemand eine Bispielprogramm, wo ich einbisschen drauf spicken könnte?
das ist doch wirklich ein triviales Problem, wenn du das nicht hinbekommst, solltest du die Finger ganz von der Programmierei lassen. Und wenn du das "machen sollst", ist wohl Sinn der Übung, dass du dir selbst Gedanken sollst.
binärzahl -10 dann in ein register speichern wie oft die 10 vorkommt und den rest dazu rechnen.
kann nicht jemand das program posten. brauchen das für die schuel XD. danke schon im voraus. lg vömi
Nochmal: Wo liegt denn das Problem? Du wirst doch wohl irgendeinen Ansatz haben? Fangen wir mal damit an: Wie lässt du den deinen Benutzer die Binärzahl eingeben bzw. wie speicherst du sie? Möglich wäre zb: Er gibt sie als String ein und gespeichert wird das Ganze daher in einem char-Array
1 | unsigned char Binaer[8]; // fuer 8-stellige Binärzahlen |
2 | // Jedes Array Element kann entweder
|
3 | // 0 oder 1 sein, je nachdem
|
Die zugehörige Dezimalzahl ist dann ganz einfach
1 | unsigned int Zahl; |
2 | |
3 | Zahl = Binaer[0] * 128 + |
4 | Binaer[1] * 64 + |
5 | Binaer[2] * 32 + |
6 | Binaer[3] * 16 + |
7 | Binaer[4] * 8 + |
8 | Binaer[5] * 4 + |
9 | Binaer[6] * 2 + |
10 | Binaer[7] * 1; |
Dein Job: Mache die Eingabe, sodass eine Eingabe von
1 | 01011111 |
dazu führt dass im Array die entsprechenden Werte gesetzt werden
1 | Binaer[0] = 0 |
2 | Binaer[1] = 1 |
3 | Binaer[2] = 0 |
4 | Binaer[3] = 1 |
5 | Binaer[4] = 1 |
6 | Binaer[5] = 1 |
7 | Binaer[6] = 1 |
8 | Binaer[7] = 1 |
Für Dezimal nach Binaer: Das machst du indem du anstatt mit 2 zu multiplizieren, fortlaufend durch 2 dividierst und den Rest betrachtest
1 | Bsp 197 |
2 | |
3 | 197 / 2 = 96 197 % 2 = 1 |
4 | 98 / 2 = 48 98 % 2 = 0 |
5 | 49 / 2 = 24 49 % 2 = 1 |
6 | 24 / 2 = 12 24 % 2 = 0 |
7 | 12 / 2 = 6 12 % 2 = 0 |
8 | 6 / 2 = 3 6 % 2 = 0 |
9 | 3 / 2 = 1 3 % 2 = 1 |
10 | 1 / 2 = 0 1 % 2 = 1 |
11 | |
12 | ^ |
13 | | |
14 | hier ist die Binärdarstellung |
15 | unten ist die höchstwertige Stelle |
197 dezimal entspricht binär 11000101
:
Bearbeitet durch User
das ist doch wirklich ein triviales Problem, wenn du das nicht hinbekommst, solltest du die Finger ganz von der Programmierei lassen.
hans peter wrote: > das ist doch wirklich ein triviales Problem, wenn du das nicht > hinbekommst, solltest du die Finger ganz von der Programmierei lassen. Immer langsam mit den jungen Pferden. Wer sowas noch nie gemacht hat und sich auch noch nie Gedanken darüber gemacht hat, wie Zahlensysteme funktionieren, kommt da alleine nicht so schnell drauf.
Das von Xyz(Gast) finde ich besser weil die Zahlen gleich im BCD -Format erscheinen.Kostet aber mehr rechenzeit.
Besten dank Herr buchegger mit dem tipp konnte ich sehr viel anfangen und bin auch schon beinahe fertig. besten dank und mit freundlichen grüssen IVO
Beitrag #5212681 wurde von einem Moderator gelöscht.
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.