浮点数转化为 2,8,16进制的数

#include<iostream.h>
#include<math.h>

void f1(int m, int n) { //转整数部分
 if(m) { f1(m/n,n);
      if(n<10) cout<<m%n;
      else m%n>=10? cout<<char(m%n-10+'A') : cout<<m%n;
 }
}

void f2(double m, int n) { //转小数部分
 while(m) { if(n<10) cout<<int(m*n);
            else m*n>=10? cout<<char(int(m*n)-10+'A') : cout<<int(m*n);
      m = m*n - int(m*n);
 }
}

void f(double m, int n) {
 f1(m, n);
 if(int(m) == m) return;
 cout<<'.';
 m -= int(m);
 f2(m, n);
}

void f10(char c[], double m) {
 cout<<' '<<c<<" 转换成"<< 2<<"进制 = "; f(m, 2); cout<<endl;
 cout<<' '<<c<<" 转换成"<< 8<<"进制 = "; f(m, 8); cout<<endl;
 cout<<' '<<c<<" 转换成"<<16<<"进制 = "; f(m,16); cout<<endl;
}

double fn_10(char c[], int n) {
 char z[100];
 int i = 0, j;
 double b = 0;
 cout<<' '<<c<<" 转换成10进制 = ";
 while(*c != '.' && *c != '\0') z[i++] = *c++;
 i--;
 if(*c == '\0') c--;
 for(j = 0; j <= i; j++)
  if(z[j] < 65) b += (z[j]-48) * pow(n,i-j);
  else          b += (z[j]-55) * pow(n,i-j);
 for(c++, j = -1; *c != '\0' ; c++, j--)
  if(*c < 65) b +=   (*c-48) * pow(n,j);
  else        b +=   (*c-55) * pow(n,j);
 cout<<b<<endl;
 return b;
}

void main() {
 cout<<"   进制转换\n";
 char c[100];
 int n;
 cout<<"\n 输入一数与它的进制: ";
 cin>>c>>n;
 cout<<endl;
    f10(c, fn_10(c,n));
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值