Šiame pavyzdyje išmoksite konvertuoti dvejetainius skaičius į dešimtainį ir atvirkščiai rankiniu būdu, sukurdami vartotojo apibrėžtą funkciją.
Norėdami suprasti šį pavyzdį, turėtumėte žinoti šias C programavimo temas:
- C funkcijos
- C Vartotojo nustatytos funkcijos
Programa konvertuoti dvejetainį į dešimtainį
#include #include int convert(long long n); int main() ( long long n; printf("Enter a binary number: "); scanf("%lld", &n); printf("%lld in binary = %d in decimal", n, convert(n)); return 0; ) int convert(long long n) ( int dec = 0, i = 0, rem; while (n != 0) ( rem = n % 10; n /= 10; dec += rem * pow(2, i); ++i; ) return dec; )
Rezultatas
Įveskite dvejetainį skaičių: 110110111 110110111 dvejetainiu = 439
Programa konvertuoti dešimtainį į dvejetainį
#include #include long long convert(int n); int main() ( int n; printf("Enter a decimal number: "); scanf("%d", &n); printf("%d in decimal = %lld in binary", n, convert(n)); return 0; ) long long convert(int n) ( long long bin = 0; int rem, i = 1, step = 1; while (n != 0) ( rem = n % 2; printf("Step %d: %d/2, Remainder = %d, Quotient = %d", step++, n, rem, n / 2); n /= 2; bin += rem * i; i *= 10; ) return bin; )
Rezultatas
Įveskite dešimtainį skaičių: 19 1 veiksmas: 19/2, likutis = 1, koeficientas = 9 2 žingsnis: 9/2, likutis = 1, koeficientas = 4 3 žingsnis: 4/2, likutis = 0, koeficientas = 2 4 žingsnis : 2/2, likutis = 0, koeficientas = 1 5 žingsnis: 1/2, likutis = 1, koeficientas = 0 19 dešimtainiu skaičiumi = 10011 dvejetainiu skaičiumi