您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“c++怎么實現數的轉換”,內容詳細,步驟清晰,細節處理妥當,希望這篇“c++怎么實現數的轉換”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
算法:
這類算法的核心,在于負數的處理,也就是用到補碼的轉換,num = ((-num)^0xffffffff)+1。
對于不同進制的轉換,采用取余數的方式,來進行操作。
對于不同數的轉換,利用 a^b 來獲取不同的數值,再通過a&(a-1)來將最右邊的1清空來操作。
題目1: 數字轉換為十六進制
代碼實現:
func toHex(num int) string { // 利用數組存儲16位數 ss := []string{"0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"} res := "" a := []string{} if num ==0 { return "0" } if num <0 { // 負數轉換為正數,采用補碼的形式 num = ((-num)^0xffffffff)+1 } for num != 0 { // 通過偏移4為的方式來計算每個十六位的數值,八進制的話是0x7 tmp := num&0xf a = append(a, ss[tmp]) num = num>>4 } // 這里位數,從左到右是高位到低位,所以要轉換 for i:= len(a)-1;i>=0;i-- { res += a[i] } return res}
題目2:整數轉換
代碼實現:
func convertInteger(A int, B int) int { // 負數轉換成補碼 if A < 0 { A = ((-A)^0xffffffff)+1 } if B < 0 { B = ((-B)^0xffffffff)+1 } t := A^B // 用來計算出A和B不同的位數1 c:=0 for t != 0{ t &= (t-1) // 用來將最右邊的1設置為0 c++ } return c}
讀到這里,這篇“c++怎么實現數的轉換”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。