十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
最简单的方液山法, 用 char * itoa(int _Val, char * _DstBuf, int _Radix);函数.
成都创新互联专注于莒南网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供莒南营销型网站建设,莒南网站制作、莒南网页设计、莒南网站官网定制、成都微信小程序服务,打造莒南网络公司原创品牌,更为您提供莒南网站排名全网营销落地服务。
用法举例:
int i = 0xaa;
森饥 char str[70] = {0};
itoa(i, str, 2); // str = "10101010"
itoa(i, str, 8); // str = "252"
itoa(i, str, 10); // str = "170"
itoa(i, str, 16); // str = "aa"
参数说明: _Val 是待转换的值, _DetBuf 是输出的字符串指针, 转换结果将存在这里面, _Radix 是进制数, 可以是你想要的任何值.
返回值是 _DetBuf 的地址, 也就是转换结果
不想用那个的话给你个函数来做
参数依次是: 要转换的值, 存储结果的字符串指针, 进制数
void xtox(long val,char *buf,unsigned radix)
{
char *p; /* 指向转换输出位置 */
char *firstdig; /* 指向第一位数字(转换后的) */
char temp; /* 临时变量 */
unsigned digval; /* 当前位的数字值 */
int is_neg; /* 是否负数 */
if (radix == 10 val 0) /* 只有10进制的才会有正负区别 */
is_neg = 1;
else
is_neg = 0;
p = buf;
if (is_neg) {
/* 是负数, 输出-号 */
*p++ = '-';
val = (unsigned long)(-(long)val); /*这样剩下的此埋返就是正数了, 转换方法都统一的*/
}
firstdig = p; /* 第一位数据开始的位置 */
do {
digval = (unsigned) (val % radix);
val /= radix; /* 获取下一位数字 */
/* 转换为字符 */
if (digval 9)
*p++ = (char) (digval - 10 + 'a'); /* 9为字母, 在转换进制10时会出现字母 */
else
*p++ = (char) (digval + '0'); /* 否则为数字 */
} while (val 0);
*p-- = '\0'; /* 字符串结束, 加上字符串结束符号 */
do { // 因为转换时候是从个位开始的, 所以转换的结果要把字符串顺序倒过来.
temp = *p; // 这里完成的就是翻转字符串
*p = *firstdig;
*firstdig = temp;
--p;
++firstdig;
} while (firstdig p);
}
1、打开visualC++6.0-文件-新建-文件-C++SourceFile。
2、输入预处理命令和主函数:
#includestdio.h /*输入输出头文件*/
voidmain()/*空类型:主函数*/
3、定义变量和数组的数据类型并输入一个十进制:
intb[16],x,k,r,i;/*定义变量和数组的数据类型为整型*/
printf("输入一个十进制:");/*输出文字提示*/
scanf("%d",x); /*输入一个十进制数字*/
k=-1;/*将-1赋给k*/
4、用除R取余倒计法将十进制的数转化成二进制的数:
do/*用循环将十进制的数转化成二进制的数*/
{
r=x%2;/*用除R取余倒计法计族败算二进制*/
b[++k]=r;/*将值赋给数组*/
x/=2;/*将原数除2*/
}while(x=1);
5、输出结果:
for(i=k;i=0;i--) /*将上面倒计的数正回来*/
printf("%d",b[i]);/*输出结果*/
printf("\n");
6、完整的源代码:
#includestdio.h铅局 /*输入输出头文兆激颤件*/
voidmain()/*空类型:主函数*/
{
intb[16],x,k,r,i;/*定义变量和数组的数据类型为整型*/
printf("输入一个十进制:");/*输出文字提示*/
scanf("%d",x); /*输入一个十进制数字*/
k=-1;/*将-1赋给k*/
do/*用循环将十进制的数转化成二进制的数*/
{
r=x%2;/*用除R取余倒计法计算二进制*/
b[++k]=r;/*将值赋给数组*/
x/=2;/*将原数除2*/
}while(x=1);
for(i=k;i=0;i--) /*将上面倒计的数正回来*/
printf("%d",b[i]);/*输出结果*/
printf("\n");
}
c语言将十进制数转换为16进制的函数:
#includestdio.h
main()
{
int u10;
char u16[10];
int w=0,a,b,i;
printf("请输入一个数字--");
scanf("%d"猛告,u10);
if(u10==0)
{
u16[0]='0';
w++;
}
else
{
a=u10;
while(a)
{
b=a%16;
if(b10)
{
u16[w]='0'+b;
}
else
{
u16[w]='A'+b-10;
}
a=a/16;
w++;
}
}
printf("\n");
printf("%d(10)转换为16进制数字为:",u10);
for(i=w-1;i=0;i--)
{
printf("%c",u16[i]);
}
printf("\n");
}
扩展资料:
十进制数转换为二进制数方法
十进制数转换为二进制数时,由于整数和小数的转换方法不同,丛尘所以先将十进制数的整数部分和小数部分分别转换后,再加以合并。
1. 十进制整数转换为二进制整数 十进制整数转换为二进制整数采用"除2取余,逆序排列"法。具体做法是:用2去除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为零时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
2.十进制小数转换为二进制小数
十进制小数转换成二进制小数采用"乘2取整,顺序排列"法。具体做法是:用2乘十进制小数,可以枝郑明得到积,将积的整数部分取出,再用2乘余下的小数部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,或者达到所要求的精度为止。
然后把取出的整数部分按顺序排列起来,先取的整数作为二进制小数的高位有效位,后取的整数作为低位有效位。
参考资料:
百度百科-十进制