Archived
1
0
Fork 0

rational.c

This commit is contained in:
nihonium 2022-02-20 16:32:02 +03:00
parent 3472194b08
commit 7d4e79bf25

47
numbers/rational.c Normal file
View file

@ -0,0 +1,47 @@
#include <stdio.h>
#include <string.h>
#include <math.h>
int main() {
char s[31] = "";
int i;
double res = 0;
char irnull = 0;
char r[31], ir[31];
scanf("%s", s);
for (i = 0; i < 31; ++i) {
if (s[i] == '.') {
s[i] = '\0';
break;
}
}
++i;
strcpy(r, s);
if (i < 32) {
strcpy(ir, s+i);
}
else {
irnull = 1;
}
// Перевод целой части
int len = strlen(r);
for (i = 0; i < len; ++i) {
res += (r[i] - '0') * pow(2, len-i-1);
}
// Если дробная часть есть, то переводим и её
if (!irnull) {
len = strlen(ir);
for (i = 1; i < len+1; ++i) {
res += (ir[i-1] - '0') * pow(2, -i);
}
}
printf ("%.12lf", res);
return 0;
}