itoa()函数,10进制转换到(2~36)进制

2024-09-07 19:18
文章标签 36 函数 转换 进制 itoa

本文主要是介绍itoa()函数,10进制转换到(2~36)进制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先看下itoa()的函数说明吧:

功 能:把一整数转换为字符串  

用 法:char *itoa(int value, char *string, int radix);   

详细解释:itoa是英文integer to array(将int整型数转化为一个字符串,并将值保存在数组string中)的缩写.   

参数:  value: 待转化的整数。

           radix: 是基数的意思,即先将value转化为radix进制的数,范围介于2-36,比如10表示10进制,16表示16进制。

          * string: 保存转换后得到的字符串。  

返回值:  char * : 指向生成的字符串, 同*string。  

备注:该函数的头文件是"stdlib.h" (包含在iostream里面)
 

记住一点:itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf。
是Windows平台下扩展的,标准库中有sprintf,功能比这个更强,用法跟printf类似。

 

 虽然可能itoa无法使用,但是我们可以编写自己的itoa()函数,以下是实现源代码(来源网络):

[cpp] view plain copy print ?
  1. char*my_itoa(int num,char*str,int radix)  
  2. {  
  3.     const char table[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ" ;  
  4.     char*ptr=str ;  
  5.     bool negative=false ;  
  6.     if(num==0)  
  7.     {  
  8.         //num=0   
  9.         *ptr++='0' ;  
  10.         *ptr='/0' ;  
  11.         // don`t forget the end of the string is '/0'!!!!!!!!!   
  12.         return str ;  
  13.     }  
  14.     if(num<0)  
  15.     {  
  16.         //if num is negative ,the add '-'and change num to positive   
  17.         *ptr++='-' ;  
  18.         num*=-1 ;  
  19.         negative=true ;  
  20.     }  
  21.     while(num)  
  22.     {  
  23.         *ptr++=table[num%radix];  
  24.         num/=radix ;  
  25.     }  
  26.     *ptr='/0' ;  
  27.     //if num is negative ,the add '-'and change num to positive   
  28.     // in the below, we have to converse the string   
  29.     char*start=(negative?str+1:str);  
  30.     //now start points the head of the string   
  31.     ptr--;  
  32.     //now prt points the end of the string   
  33.     while(start<ptr)  
  34.     {  
  35.         char temp=*start ;  
  36.         *start=*ptr ;  
  37.         *ptr=temp ;  
  38.         start++;  
  39.         ptr--;  
  40.     }  
  41.     return str ;  
  42. }  

 

程序的测试如下:

[cpp] view plain copy print ?
  1. #include <iostream>   
  2. using namespace std;  
  3. int main()  
  4. {  
  5.     int a=15;  
  6.     char str[100];  
  7.     my_itoa(a,str,15);  
  8.     cout<<str<<endl;  
  9.     return 0;  
  10. }  

 

对于已经转换到指定进制的数,此时是字符串,我们可以再转换为整型(2~10进制才可以),比如:

[cpp] view plain copy print ?
  1. int main()  
  2. {  
  3.     int a=15;  
  4.     char str[100];  
  5.     int n=atoi(my_itoa(a,str,2));  
  6.     cout<<n<<endl;  
  7.     return 0;  
  8. }  

备注:atoi()是标准库里面的函数,在C/C++语言参考函数里面有,而itoa()却没有,对此我们最好自己实现itoa()函数。

这篇关于itoa()函数,10进制转换到(2~36)进制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145928

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1