这几天看程序员面试宝典,一边学习,一边写代码实现。
下面是用c++代码实现正数转化为字符串,希望能够帮助到大家。
代码奉上,经本人测试过。
/************************正数转化为字符串**************************/
// value: 待转化的整数。
// radix: 是基数的意思,即先将value转化为radix进制的数,比如10表示10进制。
// *s: 保存转换后得到的字符串。
void my_itoa(int num, char *s, int radix) {
const char cstr[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char *pstr,*start,temp;
start = pstr = s;
bool flag = false; //记录负数
//负数
if(num < 0) {
*pstr++ = '-';
num = -num;
start = pstr;
}
//0
if(num == 0) {
*pstr++ = '0';
*pstr = '\0';
return;
}
//正数
while(num) {
*pstr++ = cstr[num%radix];
num/=radix;
}
*pstr-- = '\0';
//调换字符串的顺序
while(start < pstr) {
temp = *start;
*start = *pstr;
*pstr = temp;
start++;
pstr--;
}
}
下面是另外一种简单的实现,代码简单,效率比较低。
#include <string>
#include <sstream>
string num2str(int i) {
stringstream ss;
ss<<i;
return ss.str();
}