字符串可以转换为整型,对应的整型也可以转化为字符串。来看看吧!
题目:编程实现将整型数值转换为字符串。char *my_itoa(int value, char *buffer, int radix);
参数说明:
- value:欲转换的数值。
- buffer:目标字符串的地址。
- radix:转换后的进制数,可以是2进制,10进制、16进制等。
示例: value = 10; radix = 2; string=“1010” ;不考虑value 为负数。
【解题思路:】
这道问题的关键点是如何处理十进制以后的进制和如何存储数据。
【1. 存储数据:】
我们以示例为例,我们可以用:
value=10;
y=value%2;
保存y。
value/=2;
y每次的值,就是我们最后的结果,我们来看一张图:
最后的结果是倒着写y每次得到的结果。所以存储数据可以用栈
,即每次将y的值入栈,最后出栈放入字符串;也可以用数组
,最后从后到前放入字符串即可。
【2. 处理十六进制:】
十进制之前的转换都可以用除n取余的方式得到对应的数字转换,但是十进制后如十六进制存在字符,即10应该转换为a,11转换为b。
- 故我们可以将a,b……z字母进行一个记录,在10进制转化为2进制时,10%2=0,5%2=1,那我们可以把0……9也进行一个记录,0号下标存储0,1存储1,10存储a,以此类推,这样每次只需要从数组中取值,这就解决了十六进制的难题。如果想要输出大写的A,我们也可以在将a存储为A。
- 其次,我们用字符数组存储,那么每次取余后根据下标得到的值就是字符,也不用再进行数字到字符的转换,直接放入栈/数组,最后给字符串即可。
故定义:
char* stra="0123456789abcdefghijklmnopqrdtuvwxyz";//放入数组中的是字符,不用再转换
char* strb="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
两个数组使用一个即可。
那么每次我们的步骤就是:
while(c)
{