进制1之十进制转换成任意进制

4149: 进制1之十进制转换成任意进制

时间限制: 1.000 Sec  内存限制: 128 MB
提交: 463  解决: 291
[命题人:][下载数据: 30]

题目描述

将一个数m通过进制转换命令,将其进行转换(进制命令只有二进制、八进制、十六进制三种)。输出时如果是16进制则在输出数据前加上 0x  ,如果是8进制,则在前加上 0  ,如果是两进制则在数据最后加上 B。 
如16进制:  0x45.2d     8进制: 023.15  2进制:  110.0011B
小数部分输出位数不超过8位。

输入

23.5 2

输出

10111.1B

样例

输入  复制

23.5 2

输出  复制

10111.1B

代码:

#include <bits/stdc++.h>
using namespace std;

int main() {
	long long a,b,f=0,p,q[64];
	const string R="0123456789abcdef";
	double m;
	cin>>m>>a;
	p=m;
	if(a==16)cout<<"0x";
	if(a==8)
		cout<<"0";
	while(p!=0) {
		f++;
		q[f]=p%a;
		p=p/a;
	}
	for(int i=f; i>=1; i--) {
		cout<<R[q[i]];
	}
	cout<<'.';
	m=m-(int)m;
	for(int i=1; i<=8; ++i) {
		m=m*a;
		if(m<0.000001) break;
		cout<<R[(int)m];
		m=m-(int)m;
	}
	if(a==2)cout<<"B";
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include using namespace std; int main() { cout<<"06209527 朱**的作业!"<<endl; char arr[33],arr1[50]; //组arr用来保存用户输入的整形 int b=0; int base; //base用来保存用户欲转换进制 int len; //衡量arr的长度 double sum=0,a=0; //sum是用户输入的浮点大小 cout<<"请输入一个浮点型整的小部分"<>arr; len=strlen(arr); for(int i=0;i<len;i++) { a=arr[i]-'0'; for(int j=-1;j<i;j++) a=a/10; sum+=a; } cout<<"您输入的浮点型小是:"<<sum<<endl; cout<<"请输入你要转换进制(大于0,小于36!)"<>base; if(base36) { cout<<"输入错误!请重新输入!"<<endl; } int n=0; while(sum!=0&&n0) sum=sum-b; n++; } cout<<"转换后的小为:"<<endl; cout<<"0."; arr1[n]=0; len=strlen(arr1); for(i=0;i57) //9的ASCII码为57 { switch(arr1[i]) { case 58:cout<<"A";break; case 59:cout<<"B";break; case 60:cout<<"C";break; case 61:cout<<"D";break; case 62:cout<<"E";break; case 63:cout<<"F";break; case 64:cout<<"G";break; case 65:cout<<"H";break; case 66:cout<<"I";break; case 67:cout<<"J";break; case 68:cout<<"K";break; case 69:cout<<"L";break; case 70:cout<<"M";break; case 71:cout<<"N";break; case 72:cout<<"O";break; case 73:cout<<"P";break; case 74:cout<<"Q";break; case 75:cout<<"R";break; case 76:cout<<"S";break; case 77:cout<<"T";break; case 78:cout<<"U";break; case 79:cout<<"V";break; case 80:cout<<"W";break; case 81:cout<<"X";break; case 82:cout<<"Y";break; case 83:cout<<"Z";break; } } else cout<<arr1[i]; } return 0; }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值