经过多次计算,我终于发现了这个奥秘。用这个真的即简洁又好理解!一定要和你们分享一下。
我们都知道十六进制的字母转数字的公式是:'F'-'A'+10=15
那反过来不就是十进制转十六进制的字母了吗!!!!15-10+'A'='F'
上例题对比一下就更清楚了:
#include<stdio.h>
int main()
{
int n,i=0,j;
char a[100];
scanf("%d",&n);
if(n==0)printf("%d",n);
else
{
while(n!=0)
{
switch(n%16)
{
case 0:a[i]='0';break;
case 1:a[i]='1';break;
case 2:a[i]='2';break;
case 3:a[i]='3';break;
case 4:a[i]='4';break;
case 5:a[i]='5';break;
case 6:a[i]='6';break;
case 7:a[i]='7';break;
case 8:a[i]='8';break;
case 9:a[i]='9';break;
case 10:a[i]='A';break;
case 11:a[i]='B';break;
case 12:a[i]='C';break;
case 13:a[i]='D';break;
case 14:a[i]='E';break;
case 15:a[i]='F';break;
}
n=n/16;
i++;
}
for(j=i-1;j>=0;j--)printf("%c",a[j]);
}
return 0;
}
改造后:
#include<stdio.h>
int main()
{
int n,i=0,j;
char a[100];
scanf("%d",&n);
if(n==0)printf("%d",n);
else
{
while(n!=0)
{
if(n%16>=10&&n%16<=15)
a[i]=(n%16)-10+'A';
else a[i]=n%16+'0';
n=n/16;
i++;
}
for(j=i-1;j>=0;j--)printf("%c",a[j]);
}
return 0;
}
是不是瞬间简洁了很多呢!哈哈哈哈,我真的是太聪明啦!
(我知道你在嘲笑我,不许笑 )(•̀へ •́ ╮ )
(つд⊂)