Compare commits

..

No commits in common. "694f8ce9f49c4bad091bb473d78425460d5f8feb" and "c38a4e2090d4d169545c4bd074f856dcf71b0adf" have entirely different histories.

View File

@ -1,7 +1,6 @@
#include <stdio.h>
int umrechnen(int number);
int umrechnen2(int number);
void umrechnen(int number);
int main() {
int number = 0;
@ -16,31 +15,26 @@ int main() {
validInput = 1;
}
}
if (number >= 0) {
int erg = umrechnen(number);
printf(" %d\n", erg);
return 0;
} else {
int erg = umrechnen2(number);
printf(" %d\n", erg);
return 0;
}
umrechnen(number);
return 0;
}
int umrechnen(int number) {
if (number == 0) {
return 0;
} {
return number % 2 + 10 * umrechnen(number / 2);
}
}
int umrechnen2(int number) {
unsigned int value = number; // Interpretiere die Zahl als unsigned
void umrechnen(int number) {
int bits = sizeof(int) * 8; // Anzahl der Bits in einem int (z. B. 32 Bits)
unsigned int mask = 1 << (bits - 1); // Maske für das höchstwertige Bit
for (int i = bits - 1; i >= 0; i--) {
printf("%d", (value >> i) & 1); // Gib das i-te Bit aus
// Wenn die Zahl negativ ist, wird sie als Zweierkomplement interpretiert
unsigned int value = number;
for (int i = 0; i < bits; i++) {
// Prüfe das höchstwertige Bit und schiebe die Maske nach rechts
if (value & mask) {
printf("1");
} else {
printf("0");
}
mask >>= 1; // Schiebe die Maske um ein Bit nach rechts
}
}