halo
This commit is contained in:
parent
c38a4e2090
commit
9078f481c7
45
dualwand.c
45
dualwand.c
@ -1,6 +1,7 @@
|
||||
#include <stdio.h>
|
||||
|
||||
void umrechnen(int number);
|
||||
int umrechnen(int number);
|
||||
int umrechnen2(int number);
|
||||
|
||||
int main() {
|
||||
int number = 0;
|
||||
@ -15,26 +16,30 @@ 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;
|
||||
}
|
||||
|
||||
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
|
||||
|
||||
// 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
|
||||
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
|
||||
int bits = sizeof(int) * 8; // Anzahl der Bits in einem int (z. B. 32 Bits)
|
||||
|
||||
for (int i = bits - 1; i >= 0; i--) {
|
||||
printf("%d", (value >> i) & 1); // Gib das i-te Bit aus
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user