文档章节

十进制转换为十六进制

wannneg
 wannneg
发布于 2016/04/22 14:45
字数 501
阅读 64
收藏 2

       十进制转换为十六进制,有3种方式实现,其中两种是使用系统函数,另一种是直接自己编写。

使用系统函数实现要加入#include <stdlib.h>,自己编写则不需要这个头文件。

       下面的代码就是3种方式的实现,(2的31次方以内)都可以。可自己选择需要的实现方式。


1. char *  itoa ( int value, char * str, int base );value是要转化的数字,str是转化后的字符串存储的位置,base是进制数(但是这个函数不是标准C函数,有些编译器是不支持的!)。所以代码可以为:

char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度

char * inttohex(int aa)

{

    itoa (aa, buffer, 16);

    return (buffer);

}


2. sprintf(str,"%x",value);str是转化存储的位置,%x表示十六进制格式,value是要转化的数字。所以代码可以为:

char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度

char * inttohex(int aa)

{

    sprintf(buffer, "%x", aa);

    return (buffer);

}


3. 自己编写

如果参数是任意整数,由于计算方法是每次都除以16和对16取余数,余数以倒序的顺序排列就是结果,所以最佳方法是用递归函数(当然循环也可以,但需要最后再进行倒序)。递归代码如下:


char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度

char * inttohex(int aa)

{

    static int i = 0;

    if (aa < 16)            //递归结束条件 

    {

        if (aa < 10)        //当前数转换成字符放入字符串 

            buffer[i] = aa + '0';

        else

            buffer[i] = aa - 10 + 'A';

        buffer[i+1] = '\0'; //字符串结束标志 

    }

    else

    {

        inttohex(aa / 16);  //递归调用 

        i++;                //字符串索引+1 

        aa %= 16;           //计算当前值

        if (aa < 10)        //当前数转换成字符放入字符串 

            buffer[i] = aa + '0';

        else

            buffer[i] = aa - 10 + 'A';

    }

    return (buffer);

}


© 著作权归作者所有

上一篇: RTP介绍
wannneg
粉丝 2
博文 15
码字总数 13975
作品 0
深圳
私信 提问
Java中int的各进制之间的转换

一、二、八、十、十六进制之间的转换 int n1 = 14; //十进制转成十六进制: Integer.toHexString(n1); //十进制转成八进制 Integer.toOctalString(n1); //十进制转成二进制 Integer.toBinary...

pricker
2015/08/23
4.3K
0
二进制,十进制,八进制,十六进制

一、 进制的概念在计算机语言中常用的进制有二进制、八进制、十进制和十六进制,十进制是最主要的表达形式。 对于进制,有两个基本的概念:基数和运算规则。基数:基数是指一种进制中组成的基...

西鼠
2017/12/11
0
0
二进制、八进制、十进制、十六进制之间转换

一、 十进制与二进制之间的转换 (1) 十进制转换为二进制,分为整数部分和小数部分 ① 整数部分 方法:除2取余法,即每次将整数部分除以2,余数为该位权上的数,而商继续除以2,余数又为上一...

rainckoo
2014/11/26
388
2
补基础:自学:计算机科学导论 第二章 数字系统

2.2 位置化数字系统 在数字中符号所占据的位置决定了其表示的值。在该系统中,数字这样表示: +-(Sk-1 ……S2S1S0 ……S-l)b 它的值是: n = +-(Sk-1 bk-1 + …… + S1 b 1 + S0 b0 + S-1 b...

soulpei
2018/06/26
0
0
Java进制概述及进制间的相互转换

什么是进制? 进制也是进位制,是人们规定的一种进位方法。对于任何一种进制--X进制,就表示某一位置上的数运算时是逢X进一位。十进制是逢十进一,十六进制是逢十六进一,二进制就是逢二进一...

深情不及酒伴
2017/11/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

前端技术之:Prisma Demo服务部署过程记录

安装前提条件: 1、已经安装了docker运行环境 2、以下命令执行记录发生在MackBook环境 3、已经安装了PostgreSQL(我使用的是11版本) 4、Node开发运行环境可以正常工作 首先需要通过Node包管...

popgis
今天
5
0
数组和链表

数组 链表 技巧一:掌握链表,想轻松写出正确的链表代码,需要理解指针获引用的含义: 对指针的理解,记住下面的这句话就可以了: 将某个变量赋值给指针,实际上就是将这个变量的地址赋值给指...

code-ortaerc
今天
4
0
栈-链式(c/c++实现)

上次说“栈是在线性表演变而来的,线性表很自由,想往哪里插数据就往哪里插数据,想删哪数据就删哪数据...。但给线性表一些限制呢,就没那么自由了,把线性表的三边封起来就变成了栈,栈只能...

白客C
今天
42
0
Mybatis Plus service

/** * @author beth * @data 2019-10-20 23:34 */@RunWith(SpringRunner.class)@SpringBootTestpublic class ServiceTest { @Autowired private IUserInfoService iUserInfoS......

一个yuanbeth
今天
5
0
php7-internal 7 zval的操作

## 7.7 zval的操作 扩展中经常会用到各种类型的zval,PHP提供了很多宏用于不同类型zval的操作,尽管我们也可以自己操作zval,但这并不是一个好习惯,因为zval有很多其它用途的标识,如果自己...

冻结not
昨天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部