合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
## 基础练习 十进制转十六进制   时间限制:1.0s   内存限制:512.0MB   问题描述   十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。   给出一个非负整数,将它表示成十六进制的形式。 输入格式   输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647 输出格式   输出这个整数的16进制表示 样例输入 30 样例输出 1E ~~~ // 十进制转换十六进制 #include <iostream> using namespace std; long long num,k; char arr[10000001]; int main() { int i; while(cin>>num) { i=0; while(num/16>0) { k=num%16; if( k>=0 && k<=9 ) arr[i]=char('0'+k); else if(k>=10 && k<=15) arr[i]=char('A'+k-10); num/=16; ++i; } k=num%16; if( k>=0 && k<=9 ) arr[i]=char('0'+k); else if(k>=10 && k<=15) arr[i]=char('A'+k-10); for(k=i;k>=0;--k) cout<<arr[k]; cout<<endl; } return 0; } ~~~