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

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

usaco 1.2 Palindromic Squares(进制转化)

考察进制转化 注意一些细节就可以了 直接上代码: /*ID: who jayLANG: C++TASK: palsquare*/#include<stdio.h>int x[20],xlen,y[20],ylen,B;void change(int n){int m;m=n;xlen=0;while(m){x[++xlen]=m%B;m/=B;}m=n*n;ylen=0;whi

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

Unity3D 运动之Move函数和translate

CharacterController.Move 移动 function Move (motion : Vector3) : CollisionFlags Description描述 A more complex move function taking absolute movement deltas. 一个更加复杂的运动函数,每次都绝对运动。 Attempts to

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };