日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C/C++学习笔记:C语言实现任意进制转换,代码全解析!

發布時間:2025/3/15 c/c++ 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C/C++学习笔记:C语言实现任意进制转换,代码全解析! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題描述

給定一個 M 進制的數 x,實現對 x 向任意的一個非 M 進制的數的轉換。

問題分析

掌握不同數制間的轉換關系是解決問題的關鍵,這里所說的數制一般包括二進制、八進制、十六進制及十進制。除了不同的數制還有下面幾個必須要了解的概念。

基數:在一種數制中,只能使用一組固定的數字來表示數的大小,這組固定的數字的個數就稱為該計數制的基數(Base)。例如十進制的基數為10,二進制的基數為2等。

權:又稱為位權或權值,即每一個數位都有一個固定的基值與之相對應,稱之為權。如十進制的個位對應的權值為1(100),十位對應的權值為10(101),百位對應的權值為100(102)。對于一個 M 進制的數來說,小數點左邊各位上對應的權值從右到左分別為基數的0次方、基數的1次方、基數的2次方等,對于小數點右邊各位上對應的權值從左到右分別為基數的-1次方、基數的-2次方等。

二進制、八進制、十六進制向十進制轉換:按權展開相加。

十進制轉換成二進制、八進制、十六進制:整數部分除以基數取余數(取余的方向為從后向前);小數部分乘以基數取整數(取整的方向為從前向后)。

二進制、八進制、十六進制相互轉換:先轉換成十進制再轉換成其他進制;或者按照其對應關系進行轉換(三位二進制數對應一位八進制數,四位二進制數對應一位十六進制數)。本例題按照前一種轉換方式進行編程。

算法設計

十六進制是由 0~F 這一組固定的數字來表示,所以釆用字符數組進行存儲。在進行輸入輸出時數組元素都是以字符的形式存在的,但是在進行數制轉換時數組元素又以數值的形式存在,程序中用兩個自定義函數 char_to_number 和 number_to_char 來實現字符與其對應數值之間的轉換。

在執行程序時可以輸入多組數據來驗證程序的正確性,以前的程序都是多次運行,輸入不同的數據來實現。對程序稍做改進,只運行一次程序但可以輸入多組數據進行驗證。解決這個問題只需要加一層循環,如果循環條件為真則繼續輸入數據,否則退出。循環條件為真即表達式的值不為0,這樣可以聲明一個變量假設為 flag,利用語句 while(flag){循環體} 來進行控制,當 flag 的值為1時可以接著輸入,若為0則結束循環。

下面是完整的代碼:

#include

#define MAXCHAR 101? /*最大允許字符串長度*/

int char_to_num(char ch);? /*返回字符對應的數字*/

char num_to_char(int num);? /*返回數字對應的字符*/

long source_to_decimal(char temp[], int source);? /*返回由原數轉換成的10進制數*/

int decimal_to_object(char temp[], long decimal_num, int object);? /*返回轉換成目標數制后字符數組的長度*/

void output(char temp[], int length);? /*將字符數組逆序打印*/

int main()

{

int source;? /*存儲原數制*/

int object;? /*存儲目標數制*/

int length;? /*存儲轉換成目標數制后字符數組的長度*/

long decimal_num;? /*存儲轉換成的10進制數*/

char temp[MAXCHAR];? /*存儲待轉換的數值和轉換后的數值*/

int flag = 1;? /*存儲是否退出程序的標志*/

while(flag)? /*利用輸入的flag值控制循環是否結束*/

{

printf("轉換前的數是:");

scanf("%s", temp);

printf("轉換前的數制是:");

scanf("%d", &source);

printf("轉換后的數制是:");

scanf("%d", &object);

printf("轉換后的數是:");

decimal_num = source_to_decimal(temp, source);

length = decimal_to_object(temp, decimal_num, object);

output(temp, length);

printf("繼續請輸入1,否則輸入0:");

scanf("%d", &flag);

}

return 0;

}

/*將字符轉換成數字*/

int char_to_num(char ch)

{

if(ch>='0' && ch<='9')

return ch-'0';? /*將數字字符轉換成數字*/

else

return ch-'A'+10;? /*將字母字符轉換成數字*/

}

char num_to_char(int num)

{

if(num>=0 && num<=9)

return (char)('0'+num-0);? /*將0~9之間的數字轉換成字符*/

else

return (char)('A'+num-10);? /*將大于10的數字轉換成字符*/

}

long source_to_decimal(char temp[], int source)

{

long decimal_num = 0;? /*存儲展開之后的和*/

int length;

int i;

for( i=0; temp[i]!='\0'; i++ );

length=i;

for( i=0; i<=length-1; i++ )? /*累加*/

decimal_num = (decimal_num*source) + char_to_num(temp[i]);

return decimal_num;

}

int decimal_to_object(char temp[], long decimal_num, int object)

{

int i=0;

while(decimal_num)

{

temp[i] = num_to_char(decimal_num % object);? /*求出余數并轉換為字符*/

decimal_num = decimal_num / object;? /*用十進制數除以基數*/

i++;

}

temp[i]='\0';

return i;

}

void output(char temp[], int length)

{

int i;

for( i=length-1; i>=0; i--)? /*輸出temp數組中的值*/

printf("%c", temp[i]);

printf("");

}

運行結果:

?

總結

以上是生活随笔為你收集整理的C/C++学习笔记:C语言实现任意进制转换,代码全解析!的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。