十进制转十六进制 C/C++蓝桥杯基础试题BASIC-10

问题描述

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

思路

        定义一个字符数组来存储结果。如果输入为0则输出为字符"0",否则不断用a模除16来获得十六进制的每一位。这个过程就类似将十进制123分为3、2、1,需要将123%10得到3,再将123除以10得到12,重复这个过程得到2、1,表示123中有三个1、两个10和一个100。

        例如十进制数18,首先模除16得到最末一位2,再除以16得1,此时进入第二次循环,2模除16得前面一位2,再除以16得0,不会进入第三次循环。最后的结果就是十六进制的12,表示有一个十进制的16和一个十进制的2。

满分代码

#include 
int main()
{
    int a, i = 0;
    char s[30];
   
    scanf("%d", &a);
    if(a==0){
    	printf("0");
	}else{
		while (a)
    	{
        	if (a % 16 >= 10)
            	s[i] = a % 16 + 55;    //从A开始 
        	else
            	s[i] = a % 16 + 48;    //从0开始 
        	i++;
        	a = a / 16;
    	}
    	s[i] = '\0'; 
    	for (i = i-1; i >= 0; i--)
        	printf("%c", s[i]);
	}
    
    return 0;
}

蓝桥杯注意事项

仅限C/C++类:

1. 代码必须有一个return 0;否则会报运行错误;

2. for(  ;   ;    )中不能定义变量,如for(int i=0;i<10;i++),这样编译会不过,可以在前面单独定义int i;

3. 如果输出要求是从大到小输出什么数而没有特殊要求格式,则printf("%d空格")和printf("%d\n")目前看不影响结果。

你可能感兴趣的:(蓝桥杯,算法,c语言)