现在的位置: 首页 > 综合 > 正文

正数转化为字符串

2013年01月25日 ⁄ 综合 ⁄ 共 732字 ⁄ 字号 评论关闭

         这几天看程序员面试宝典,一边学习,一边写代码实现。

      下面是用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();
}

抱歉!评论已关闭.