13-进制转换
2018-02-23 08:19
155 查看
问题描述:
输入一个十进制数 N,将它转换成R 进制数输出。在 10≤R≤16的情况下,用'A'表示 10,用
'B'表示11,用
'C'表示12,用
'D'表示13,用
'E'表示14,用
'F'表示15。
输入格式
输入包含两个整数 N(N≤10000)和 R(2≤R≤16)。注意,N有可能是负整数。
输出格式
输出一行,表示转换后的数。样例输入
23 12
样例输出
1B
代码详解:
#include <bits/stdc++.h>using namespace std;
int main(){
int count=0;//count the index
int N;//the number
int R;//the R
int remainder;
char item[100001];//the array
cin>>N>>R;
int Number=abs(N);
//
while(Number){
remainder=Number%R;
if(remainder>=10){
switch(remainder){
case 10:item[count++]='A';break;
case 11:item[count++]='B';break;
case 12:item[count++]='C';break;
case 13:item[count++]='D';break;
case 14:item[count++]='E';break;
case 15:item[count++]='F';break;
}
}
else
item[count++]=remainder+'0';
Number=Number/R;
}
if(N<0)cout<<"-";
if(count==0)cout<<0;
else{
for(int i=count-1;i>=0;i--){
cout<<item[i];
}
}
return 0;
}
相关文章推荐
- 【C++心路历程13】进制转换
- codeforces 13a(进制转换)
- Linux实战教学笔记13-定时任务补充
- Project Euler 13 Large sum(大数加法)
- 构建之法13-17章读后感
- LintCode 13 字符串查找
- xps 13格式化安装win7问题
- 阅读《构建之法》13-17章
- FR #13题解
- 13-01-23-->8
- (林雷看来13):功能优先,发展和重建同步,业绩后
- 科锐课堂笔记:2017/2/22 进制转换与编码
- 2013-01-25 13:15pm php指针的函数
- java学习之旅07--整数类型_进制转换_编程中的L问题
- H5 13-子元素选择器
- 13书籍推荐
- java学习之旅13--运算符_01_算术_逻辑_位运算符_扩展运算符
- CCNA 13DHCP技术
- 跟我一起玩Win32开发(13):握手对话框
- 学习笔记_Java_day12_设计模式MVC(13).JavaWeb的三层框架(14)