c算法练习1——十进制转十六进制数

算法题目:

​ 十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有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进制表示

代码:

#include <stdio.h>
int n;
char result[10];

int main(){
    
    
        scanf("%d",&n);  //接收标准输入
        int i =0;
        int temp=0;
        while(n!=0){
    
     
                temp = n%16;
                if(temp<=9){
    
    
                         result[i]=temp+'0'; //0~9的数字加上'0',可以将数字转化为字符
                }
                else{
    
    
                        result[i] = ((temp-10)+'A');  //字符加上数字等同于ascall的计算
                }
                i++;
                n = n/16;
             }
        // 循环输出数组内容,sizeof()计算数组长度。
        for(int p=sizeof(result)-1;p>=0;p--)
                printf("%c",result[p]);
}

在线进制转换网站
C语言在线编译器

猜你喜欢

转载自blog.csdn.net/quxuexi/article/details/124986440