下面筆者說說自己對進制轉換的分析:
筆者認為,任何進制都可以直接轉換到十進制,而十進制也可以相當容易的轉換到其他進制,所以筆者在這里將十進制作為中間變量,任何進制通過它,都可以進行相互轉換.
筆者先說說將其他進制轉換到十進制的方式
if (n > 0)
{
long count = 1;
for (int j = 0; j < num.Length - i - 1; j++)
{
count *= format;
}
count *= n;
allCount += count;
}
}
return allCount;
}
allCount:用于保存轉換后的十進制數據
n:保存十六進制或者32進制返回的數據;(16進制與32進制包含了字符,所以這里必須根據相應的字符進行轉換)
這里,如果n>0,這里則需要進行計算,算法我已經寫在for循環中了,下面具體說說這個算法
從外層循環開始:
num.length:當前進制的字符總長;這里循環它,主要是為了得到它每一位的數據大小,最后疊加;
有朋友問我,為什么不適用foreach呢,這樣就不用substring截取了.至于原因,我后面在說吧;
這里有個方法,GetNumberByStr(string s):這里主要是處理16進制與32進制的,也就是帶字母的數據轉換./
在定義這個方法前,我們需要定義一個參數,用于保存這些數據
下面我們來寫GetNumberByStr這個方法
獲取當前字母所在位置,在結果后追加10,如此,便可以得到我們所需要的相應字符,二進制八進制是不需要進入這個方法的
好,我們繼續說;當數據真實存在(當前位數大于0,等于0則不用去操作)時,定義count=1,用于保存當前位轉換后的十進制數據
內存循環;這里主要是看看當前位數是當前進制的幾次方,如二進制的1110,從左向右算,第一位應該是2的3次方,以此類推,第四位應該是二的0次方,這里的循環就是做了這樣的操作,相應的,當前所在位置的次方也就是字符長度-i-1,這里就是我為什么要保留for循環,留下i的原因;format也就是進制,二進制則為2.八進制則為8;最后,很重要的一個操作,
count*=n;這個對于二進制來說作用并不大,也可以說是沒有作用,因為二進制最大的數字就是1,所以可以忽略不計,但是其他進制則需要,當前位的數字表示了當前我們算出的結果倍數.如32進制的10;其實就是32,20則為64.就是這樣得出的
最后都追加到allCount.return出去.ok,我們已經完成了其他進制到十進制的轉換,下面我們只要轉回去就可以了;
代碼如下
方法很簡單,不到10行代碼,我要說的只有2點
1:這里str用于拼接數據,要注意的是,這里得出的每一位的結果,需要追加到最前面,所以使用insert來插入到第一位
2:SixFont(long num):這個方法是用于轉換數據的,用于16和32進制,大于10的數據是字符,我的處理方式是截取字符串,避免過多的判斷或者case;
恩,這樣就基本完成了,其他進制之間的轉換也就可以通過這樣的方式來完成了
還有不理解的朋友可以聯系我qq(1772282755);源碼地址http://xiazai.VeVB.COm/201311/yuanma/jinzhizhuanhuan(VeVB.COm).rar
新聞熱點
疑難解答