十進制轉(zhuǎn)換函數(shù)c語言 十六進制轉(zhuǎn)十進制函數(shù)c語言

C語言十進制轉(zhuǎn)二進制

十進制轉(zhuǎn)二進制可以使用庫函數(shù)itoa。

創(chuàng)新互聯(lián)建站是一家以成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、品牌設(shè)計、軟件運維、成都網(wǎng)站推廣、小程序App開發(fā)等移動開發(fā)為一體互聯(lián)網(wǎng)公司。已累計為除甲醛等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開發(fā)服務(wù)。

itoa函數(shù)原型:char*itoa(int value,char*string,int radix);

功能:將任意類型的數(shù)字轉(zhuǎn)換為字符串。在stdlib.h中與之有相反功能的函數(shù)是atoi。

nt value 被轉(zhuǎn)換的整數(shù),char *string 轉(zhuǎn)換后儲存的字符數(shù)組,int radix 轉(zhuǎn)換進制數(shù),如2,8,10,16 進制等。

擴展資料:

方法

#includestdio.h

int?main(void)

{ int?i=0,n,a[32];

printf("請輸入一個十進制整數(shù).\n");

scanf("%d",n);

while?(n0)

{a[i]=n%2;

i=i+1;

n=n/2;? }

printf("十進制整數(shù)轉(zhuǎn)換為二進制數(shù)是:\n");

for(i--;i=0;i--)

printf("%d",a[i]);

printf("\n");

return?0;}

十進制整數(shù)轉(zhuǎn)換為二進制整數(shù)的方法:

十進制整數(shù)轉(zhuǎn)換為二進制整數(shù)采用"除2取余,逆序排列"法。

具體做法是:用2去除十進制整數(shù),可以得到一個商和余數(shù);再用2去除商,又會得到一個商和余數(shù),如此進行,直到商為零時為止,然后把先得到的余數(shù)作為二進制數(shù)的低位有效位,后得到的余數(shù)作為二進制數(shù)的高位有效位,依次排列起來。

求十進制轉(zhuǎn)換二進制C語言代碼

求十進制轉(zhuǎn)換二進制C語言代碼代碼如下:

#include stdio.h

#define? NR (sizeof(int)*8)? // 二進制位的個數(shù)

void deciToBin(int num); // 十進制轉(zhuǎn)換為二進制函數(shù)聲明

/* 主函數(shù) */

int main(void)

{

int num;

fprintf(stdout, "請輸入一個正整數(shù):");

/* 獲取并檢查用戶輸入 */

while (1)

{

if (fscanf(stdin, "%d", num) != 1)

{

fprintf(stderr, "輸入錯誤!請重新輸入:");

while (getchar() != '\n'); // 去掉多余的非法字符

continue;

}

else if (num 0)? ? ? ? ? ? ?// 輸入的數(shù)不能為負數(shù)

{

fprintf(stderr, "請輸入錯誤!請輸入正整數(shù):");

continue;

}

else

break;

}

fprintf(stdout, "對應(yīng)二進制為:");

#if 1 /* 方法一: 不使用遞歸 */

char bitArr[NR];

int i = -1;

/* 算法:棧的數(shù)學(xué)模型 */

do {

i += 1;

bitArr[i] = num % 2;

num /= 2;

} while (num != 0);

/* 逆序打印 */

for (i ; i = 0; i--)

{

fprintf(stdout, "%d", bitArr[i]);

}

fputc('\n', stdout);

#else /* 方法二: 使用遞歸 */

if (num == 0)

{

fprintf(stdout, "0\n");

}

else

{

deciToBin(num);? ? ? ?// 調(diào)用第歸函數(shù)

fputc('\n', stdout);

}

#endif

return 0;

}

/*

* @函數(shù)名:deciToBin

* @函數(shù)功能:實現(xiàn)十進制轉(zhuǎn)換為二進制

* @參數(shù):需要轉(zhuǎn)換的十進制整數(shù)

*/

void deciToBin(int num)

{

/* 第歸結(jié)束條件 */

if (num == 0)

{

return;

}

/* 第歸調(diào)用 */

deciToBin(num/2);

/* 逆序打印 */

fprintf(stdout, "%d", num%2);

}

擴展資料:

使用C語言編程實現(xiàn)任意進制數(shù)(2-16進制)轉(zhuǎn)換為其他任意進制數(shù)(2-16進制)方法:

#includestdio.h

#includestring.h

#includestdlib.h

int TenNum(char a[],int B);

void Numchange(int m, int B);

int TenNum(char a[], int B)

{

int len, i, num;

int sum = 0;? ?

len = strlen(a);

for (i = 0; i len; i++)

{

if (a[i] = '0' a[i] = '9')

num = a[i] - '0';

else if (a[i] = 'A' a[i] = 'F')

num = a[i] - 'A' + 10;

sum = sum * B + num;

}

return sum;

}

void Numchange(int m, int B)

{

int n;

if (m)

{

Numchange(m / B, B);

n = m % B;

if (n 10)

printf("%d", n);

else

printf("%c", n + 55);

}

}

int main()

{

int B, b;

char a[20];? ? ?

printf("請輸入待轉(zhuǎn)換數(shù)的進制(2-16):");

do {

scanf_s("%d", B);? ? ? ?

} while (B 2 B 16);

printf("請輸入待轉(zhuǎn)換數(shù):");

getchar();? ? ? ?

gets_s(a);

int m = TenNum(a, B);

printf("請輸入需要轉(zhuǎn)成幾進制數(shù)(2-16):");

do {

scanf_s("%d", b);

} while (B 2 B 16);

printf("%d進制數(shù)%s轉(zhuǎn)換為%d進制數(shù)的結(jié)果為:",B,a,b);

Numchange(m, b);

printf("\n");

system("pause");

return 0;

}

求c語言將十進制數(shù)轉(zhuǎn)換為16進制的函數(shù)

c語言將十進制數(shù)轉(zhuǎn)換為16進制的函數(shù):

#includestdio.h

main()

{

int u10;

char u16[10];

int w=0,a,b,i;

printf("請輸入一個數(shù)字--");

scanf("%d",u10);

if(u10==0)

{

u16[0]='0';

w++;

}

else

{

a=u10;

while(a)

{

b=a%16;

if(b10)

{

u16[w]='0'+b;

}

else

{

u16[w]='A'+b-10;

}

a=a/16;

w++;

}

}

printf("\n");

printf("%d(10)轉(zhuǎn)換為16進制數(shù)字為:",u10);

for(i=w-1;i=0;i--)

{

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

}

printf("\n");

}

擴展資料:

十進制數(shù)轉(zhuǎn)換為二進制數(shù)方法

十進制數(shù)轉(zhuǎn)換為二進制數(shù)時,由于整數(shù)和小數(shù)的轉(zhuǎn)換方法不同,所以先將十進制數(shù)的整數(shù)部分和小數(shù)部分分別轉(zhuǎn)換后,再加以合并。

1. 十進制整數(shù)轉(zhuǎn)換為二進制整數(shù) 十進制整數(shù)轉(zhuǎn)換為二進制整數(shù)采用"除2取余,逆序排列"法。具體做法是:用2去除十進制整數(shù),可以得到一個商和余數(shù);再用2去除商,又會得到一個商和余數(shù),如此進行,直到商為零時為止,然后把先得到的余數(shù)作為二進制數(shù)的低位有效位,后得到的余數(shù)作為二進制數(shù)的高位有效位,依次排列起來。

2.十進制小數(shù)轉(zhuǎn)換為二進制小數(shù)

十進制小數(shù)轉(zhuǎn)換成二進制小數(shù)采用"乘2取整,順序排列"法。具體做法是:用2乘十進制小數(shù),可以得到積,將積的整數(shù)部分取出,再用2乘余下的小數(shù)部分,又得到一個積,再將積的整數(shù)部分取出,如此進行,直到積中的小數(shù)部分為零,或者達到所要求的精度為止。

然后把取出的整數(shù)部分按順序排列起來,先取的整數(shù)作為二進制小數(shù)的高位有效位,后取的整數(shù)作為低位有效位。

參考資料:

百度百科-十進制

C語言編寫一個函數(shù)將十進制轉(zhuǎn)換

#includestdio.h

void P(int a,int n){

int i,p[30]={0};

p[0]=a;

for(i=1;i30;i++){

p[i]=p[i-1]/n;

p[i-1]%=n;}

for(i=29;i=0;i--)if(p[i]!=0)break;

for(;i=0;i--)printf("%d ",p[i]);}

int main(){

int a,n;

printf("輸入一個整數(shù)\n");

scanf("%d",a);

printf("輸入要轉(zhuǎn)換的進制\n");

scanf("%d",n);

P(a,n);

return 0;}

標(biāo)題名稱:十進制轉(zhuǎn)換函數(shù)c語言 十六進制轉(zhuǎn)十進制函數(shù)c語言
標(biāo)題URL:http://www.muchs.cn/article2/doodcic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、網(wǎng)站改版、網(wǎng)站導(dǎo)航、ChatGPT、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)