整型进制转换程序
1. 簡述
??? 實際上,小數也是存在進制轉換的,本文主要給出整型的進制轉換代碼實現。函數原型如下:
??? char* ChangeFromDecimal(unsigned int value, int base);
?? ?// value:10進制的數值;base:轉化成的進制數;返回值:轉化后的進制數,最后還增加了'\0'
??? int ChangeToDecimal(char* value, int base);
??? // 工作與ChangeFromDecimal相反,將某種進制的字符串表示,轉化為int數值
2. 代碼實現???
#include?<iostream>#include?<stack>
using?namespace?std;
char*?ChangeFromDecimal(unsigned?int?value,?int?base)?{
??char*?result;
??stack<char>?result_stack;
??unsigned?int?tmp; ? result_stack.push('\0');
??while(value)?{
????tmp?=?value?%?base;
????value?=?value?/?base;
????result_stack.push(tmp?<?10???(tmp+'0')?:?(tmp-10+'A'));
??}
??result?=?new?char[result_stack.size()];
??tmp?=?0;
??while(!result_stack.empty())?{
????result[tmp++]?=?result_stack.top();
????result_stack.pop();
??}
??return?result;
}
int?ChangeToDecimal(char*?value,?int?base)?{
??int?result?=?0;
??while(*value?!=?'\0')?{
????result?=?result?*?base;
????result?+=?(*value)<='9'?(*value-'0'):(*value-'A'+10);
????value++;
??}
??return?result;
}?
int?main()?{
??int?num?=?253;
??char?*result;??
??cout?<<?(result?=?ChangeFromDecimal(num,?2))?<<?endl;
??cout?<<?ChangeToDecimal(result,?2)?<<?endl;
??cout?<<?"----------------------------------------"?<<?endl;
??delete?[]result;
??cout?<<?(result?=?ChangeFromDecimal(num,?8))?<<?endl;
??cout?<<?ChangeToDecimal(result,?8)?<<?endl;
??cout?<<?"----------------------------------------"?<<?endl;
??delete?[]result;
??cout?<<?(result?=?ChangeFromDecimal(num,?16))?<<?endl;
??cout?<<?ChangeToDecimal(result,?16)?<<?endl;
??delete?[]result;
??result?=?0;
??system("PAUSE");
??return?0;
}
3. 重點說明
????· 對于大于等于10的數字和小于10的數字要分別處理,尤其是'0'-'9'與'A'-'Z'的ASCII碼是不連續的。
??? · 如果使用參數代替返回值的話,對于char*,要使用char*&,對于int,要使用int*。
??? · 由于英文字母有限,base是有限制的,10個數字加上26個字母,最多能夠表示的也就是36進制。
??? · 最重要的一點是第一個函數將int轉化為字符串進制時,一定要將int解釋為unsigned int,因為函數中用到了取余運算,如果不解釋的話,對于負數,計算后顯示會出錯的。 而第二個函數卻不需要一定返回unsigned int,返回int也可以的,因為其中,只是對數值進行乘法和加法。當然,全部使用unsigned int實際上是最保險的方式,也是最安全的。如果都用unsigned int,第一個函數傳入int,就會直接被轉化為unsigned int,只要對第二個函數的返回值,強制轉化為int,即可得到合理的顯示。
總結
 
                            
                        - 上一篇: SQLDump***.txt
- 下一篇: Exception在语义上的处理。在系统
