欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言的進制轉(zhuǎn)換及算法實現(xiàn)教程

 更新時間:2021年01月23日 16:24:12   作者:別光想著,趕緊去做  
這篇文章主要介紹了C語言的進制轉(zhuǎn)換及算法實現(xiàn)的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1、其他進制轉(zhuǎn)十進制

1.1、二進制轉(zhuǎn)十進制

轉(zhuǎn)換規(guī)程: 從最低位開始,將每個位上的數(shù)提取出來,乘以2的(位數(shù)-1)次方,然后求和,例如: 

二進制 1011 = 1*2^0 + 1*2^1 + 0*2^2 + 1*2^3 = 1 + 2 + 0 + 8 = 11

1.2、八制轉(zhuǎn)十進制

轉(zhuǎn)換規(guī)則: 從最低位開始,將每個位上的數(shù)提取出來,乘以8的(位數(shù)-1)次方,然后求和,例如:

 八進制 0123 = 3*8^0 + 2*8^1 + 1*8^2 = 3+16+64 = 83

1.3、十六進制轉(zhuǎn)十進制

轉(zhuǎn)換規(guī)則: 從最低位開始,將每個位上的數(shù)提取出來,乘以16的(位數(shù)-1)次方,然后求和,例如:

  十六進制 0x34A = 10*16^0 + 4*16^1 + 3*16^2 = 10+64+768 = 842

2、十進制轉(zhuǎn)其他進制

2.1、十進制轉(zhuǎn)二進制binary

規(guī)則: 將該數(shù)不斷除以2,直到商為0為止,然后將每步得到的余數(shù)倒過來,就是對應的二進制,故此法叫做除商逆序取余法;

案例: 將56轉(zhuǎn)換為二進制

 56 :
 56 / 2 = 28 余0
 28 / 2 = 14 余0
 14 / 2 = 7 余0
 7 / 2 = 3 余1
 3 / 2 = 1 余1
 1 / 2 = 0余 1
 故56轉(zhuǎn)換為二進制的結果是:111000

代碼實現(xiàn):

#include <stdio.h>

//轉(zhuǎn)十進制二進制
void main() {
	printf("請輸入一個十進制數(shù):");
	int binary = 0; //二進制數(shù)
	int b = 1; //循環(huán)標志		 
	int num[100] ; //用來存二進制的數(shù)組
	int index = 0;	//數(shù)組的下標
	int count = -1; //用來計算數(shù)組的使用個數(shù),這里使用-1是因為數(shù)組的下標是從0開始的
	//所以當我們循環(huán)一次去自增的時候,第一次應該是從0開始,如果count的初始值是0的話
	//就會導致使用的第一個數(shù)組的下標為1,那樣會導致存數(shù)據(jù)的下標index和記錄使用的下標count不一致
	//使數(shù)據(jù)溢出
	scanf("%d",&binary);
	while (b) {
		num[index] = binary % 2; //每次運算取余
		binary /= 2; //每次運算二進制數(shù)需要除以2
		//printf("num[%d]=%d\n",index,num[index]);
		index++; //每循環(huán)一次數(shù)組下標就移一位
		count++; //每循環(huán)一次就表示占用了數(shù)組的一個位置
		if (binary == 0) {
			b = 0;
		}
	}
	printf("占用數(shù)組位置%d個",count+1);
	printf("\n");
	printf("二進制數(shù)為:");
	for (int i = count; i >=0; i--) { 
			printf("%d",num[i]);
	}
	getchar();
	getchar();//回車會被接收,所以需要兩個來暫??刂婆_
}

2.2、十進制轉(zhuǎn)八進制octonary

規(guī)則: 將該數(shù)不斷除以8,直到商為0,然后將每步得到的余數(shù)倒過來,就是對應的八進制。

**案例:**將156轉(zhuǎn)換為八進制

 156:
 156 / 8 = 19 余 4
 19 / 8 = 2 余 3
 2 / 8 = 0 余 2
 故156轉(zhuǎn)換為八進制的結果是:0234

代碼實現(xiàn):

#include <stdio.h>
//十進制轉(zhuǎn)八進制
#define TRUE 1 //宏定義 true為1
#define FALSE 0//宏定義 false為0
void main() {
	int num[100]; //定義數(shù)組用來存儲轉(zhuǎn)換后的八進制數(shù)
	int octonary = 0; //十進制數(shù)
	int b = TRUE; //循環(huán)賦值的標志
	int index = 0; //存儲八進制位數(shù)的下標
	int count = -1; //八進制數(shù)的位數(shù)
	printf("請輸入一個十進制數(shù):");
	scanf("%d",&octonary);
	while (b) {
		num[index++] = octonary % 8; //獲取余數(shù)
		octonary /= 8; //累除
		count++;
		if (octonary == 0) { //當octonary為0時,表示已經(jīng)除完了,除到底了,這時候只需要將所得到的的余數(shù)
			b = FALSE;		//倒過來就是需要求的八進制數(shù)了
		}
	}
	printf("占用數(shù)組位置%d個\n",count+1);
	printf("八進制數(shù)為:");
	for (int i = count; i >= 0; i--) {
		printf("%d",num[i]);
	}

	getchar();
	getchar();

}

2.3、十進制轉(zhuǎn)十六進制HEX(hexadecimal)

規(guī)則: 將該數(shù)不斷除以16,直到商為0,然后將每步得到的余數(shù)倒過來,就是對應的十六進制。

案例: 將356轉(zhuǎn)換成十六進制

 356:
 356 / 16 = 22 余 4
 22 / 16 = 1 余 6
 1 / 16 = 0 余 1
 故356轉(zhuǎn)換為十六進制的結果為0x164

代碼實現(xiàn):

#include <stdio.h>
#include <stdbool.h>
//十進制轉(zhuǎn)換為十六進制
void main() {
	int hexadecimal = 0;
	printf("請輸入一個十進制數(shù):");
	scanf("%d",&hexadecimal);
	bool b = true;
	int index = 0;//數(shù)組的下標
	int num[100];//用來存儲轉(zhuǎn)換后十六進制
	while (b) {
		num[index++] = hexadecimal % 16;
		hexadecimal /= 16;
		if (hexadecimal == 0) {
			b = false;
		}
	}
	printf("占用數(shù)組的位置%d個\n",index);
	printf("轉(zhuǎn)換后的十六進制數(shù)為:");
	for (int i = index-1; i >= 0; i--) {
		printf("%d",num[i]);
	}
	getchar();
	getchar();
}

3、二進制轉(zhuǎn)其他進制

3.1、二進制轉(zhuǎn)八進制

規(guī)則: 從低位開始,將二進制數(shù)每三位一組(111表示7)分組,不夠的用0補充,將每一組轉(zhuǎn)換成對應的八進制即可

案例: 將11010101轉(zhuǎn)成八進制

 11010101:對其進行三位一體分組
 第一組:101 ——>  5
 第二組:010 ——>  2
 第三組:011 ——>  3
 故,二進制11010101對應的八進制數(shù)是:0325

3.2、二進制轉(zhuǎn)十六進制

規(guī)則: 從低位開始,將二進制數(shù)每四位一組(1111表示F)進行分組,轉(zhuǎn)成對應的十六進制數(shù)即可

案例: 將11010101轉(zhuǎn)成十六進制

 11010101:對其進行四位一體分組
 第一組:0101 ——> 5
 第二組:1101 ——> 13
 故,二進制11010101轉(zhuǎn)換為十六進制數(shù)是:0xD5

4、其他進制轉(zhuǎn)二進制

4.1、八進制轉(zhuǎn)二進制

規(guī)則: 將八進制數(shù)的每一位,轉(zhuǎn)換成對應的一個三位的二進制數(shù)即可

案例: 將0237轉(zhuǎn)成二進制

 0237:每一位對應三位二進制數(shù)進行拆分
 第一組 7 ——> 111
 第二組 3 ——> 011
 第三組 2 ——> 010
 故,八進制數(shù)0237轉(zhuǎn)換為二進制為:10011111

4.2、十六進制轉(zhuǎn)二進制

規(guī)則: 將十六進制數(shù)的每一位,轉(zhuǎn)換成對應的一個四位的二進制數(shù)即可

案例: 將0X23B轉(zhuǎn)換成二進制數(shù)

 0x23B:每一位對應四位二進制數(shù)進行拆分
 第一組 B ——> 1011
 第二組 3 ——> 0011
 第三組 2 ——> 0010
 故,0x23B轉(zhuǎn)換為二進制數(shù)為:1000111011

總結

到此這篇關于C語言的進制轉(zhuǎn)換及算法實現(xiàn)的文章就介紹到這了,更多相關C語言進制轉(zhuǎn)換及算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C語言實現(xiàn)掃雷小游戲完整算法詳解(附完整代碼)

    C語言實現(xiàn)掃雷小游戲完整算法詳解(附完整代碼)

    掃雷游戲想必我們都有玩過,那么今天就用C語言來簡單實現(xiàn)“掃雷”小游戲,這篇文章主要給大家介紹了關于C語言實現(xiàn)掃雷小游戲完整算法的相關資料,文中給出了完整的實例代碼,需要的朋友可以參考下
    2022-06-06
  • C/C++語言中的頭文件匯總

    C/C++語言中的頭文件匯總

    這篇文章主要匯總了C/C++語言中的頭文件,方便各位朋友更好的工作和學習,有需要的朋友可以參考下
    2020-06-06
  • C++實現(xiàn)LeetCode(557.翻轉(zhuǎn)字符串中的單詞之三)

    C++實現(xiàn)LeetCode(557.翻轉(zhuǎn)字符串中的單詞之三)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(557.翻轉(zhuǎn)字符串中的單詞之三),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++ vector 遍歷的幾種方法

    C++ vector 遍歷的幾種方法

    本文主要介紹了C++ vector 遍歷的幾種方法,對vector 遍歷有一定的總結,具有一定的參考價值,感興趣的可以了解一下
    2021-07-07
  • C語言實現(xiàn)放煙花的程序

    C語言實現(xiàn)放煙花的程序

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)放煙花的程序,有音樂播放,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • C語言函數(shù)的遞歸調(diào)用詳情

    C語言函數(shù)的遞歸調(diào)用詳情

    這篇文章主要介紹了C語言函數(shù)的遞歸調(diào)用詳情,遞歸做為一種算法在程序設計語言中廣泛應用,主要的思考方式就是大事化小,下文具體的相關介紹,需要的小伙伴可以參考一下
    2022-04-04
  • C語言實現(xiàn)發(fā)牌洗牌

    C語言實現(xiàn)發(fā)牌洗牌

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)發(fā)牌洗牌,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++面試題之結構體內(nèi)存對齊計算問題總結大全

    C++面試題之結構體內(nèi)存對齊計算問題總結大全

    這篇文章主要給大家總結了關于C++面試題中結構體內(nèi)存對齊計算問題的相關資料,文中通過示例代碼介紹的非常詳細,通過這些介紹的內(nèi)容對大家在面試C++工作的時候,會有一定的參考幫助,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-08-08
  • Qt讀取Json文件的方法詳解(含源碼+注釋)

    Qt讀取Json文件的方法詳解(含源碼+注釋)

    QT本身就有讀取json的接口,簡單又方便,下面這篇文章主要給大家介紹了關于Qt讀取Json文件(含源碼+注釋)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • 深入了解C++智能指針的使用

    深入了解C++智能指針的使用

    智能指針的本質(zhì)就是使用一個對象來接管一段開辟的空間,在該對象在銷毀的時候,自動調(diào)用析構函數(shù)來釋放這段內(nèi)存。本文就來和大家詳細聊聊智能指針的使用,需要的可以參考一下
    2022-10-10

最新評論