将整数转化为一个任意进制的字符串,将任意进制的字符串转化为一个整数的代码
2014-01-13 13:41
316 查看
// 将整数转化为一个任意进制的字符串 static void int_to_string(int value, char* szDest, int type = 10) { bool negative = false; if (value < 0) { negative = true; value = -value; } int index = 0; int nDecNum; char szTmp[128]; memset(szTmp, 0, 128); while (value && index < 128) { nDecNum = value % type; value /= type; if (nDecNum < 10) { szTmp[index] = '0' + nDecNum; } else { szTmp[index] = 'A' + nDecNum - 10; } index++; } int pos = 0; if (negative) { szDest[pos] = '-'; pos++; } for (int i = index - 1; i >= 0; i--) { szDest[pos] = szTmp[i]; pos++; } szDest[pos] = 0; }
static int GetNum(char c) { if (c >= '0' && c <= '9') { return c - '0'; } else if (c >= 'a' && c <= 'z') { return c + 10 - 'a'; } else if (c >= 'A' && c <= 'Z') { return c + 10 - 'A'; } else { return -1; } } // 将任意进制的字符串转化为一个整数 static bool string_to_int(const char* szSrc, int& value, int type = 10) { value = 0; int nDecNum; int len = (int)strlen(szSrc); int n = 1; for(int i = len - 1; i >= 0; i--) { nDecNum = GetNum(szSrc[i]); if (nDecNum == -1) { return false; } value += nDecNum * n; n *= type; } return true; }
相关文章推荐
- 将整数转化为一个任意进制的字符串,将任意进制的字符串转化为一个整数的代码
- 整数转化为任意n进制的字符串
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 设计一个算法把一个十进制整数转化为二至九进制之间的任意进制数输出
- c函数实现将一个整数转为任意进制的字符串输出
- 将一个整数N转换成字符串!(递归和非递归、及——进制转化)
- 递归 将一个十进制数转化为任意进制字符串
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 2.写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 4.2题目: 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 一个将任意字符或字符串按位转化为整数的方法
- 请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出
- 10. 编码:写一个c函数,实现将16进制表现形式的字符串转化为整数。例如,输入”1a”,返回26,输入“FE”,返回254
- git是一种分布式代码管理工具,git通过树的形式记录文件的更改历史,比如: base'<--base<--A<--A' ^ | --- B<--B' 小米工程师常常需要寻找两个分支最近的分割点,即base.假设git 树是多叉树,请实现一个算法,计算git树上任意两点的最近分割点。 (假设git树节点数为n,用邻接矩阵的形式表示git树:字符串数组matrix包含n个字符串,每个字符串由字符'0
- 求一个数中任意的某一段,(可以转化为其他进制)
- 怎么将一个16进制字符串转化为10进制输出?
- c++将一个字符串转化为指定进制的数