十進(jìn)制轉(zhuǎn)二進(jìn)制可以使用庫(kù)函數(shù)itoa。
創(chuàng)新互聯(lián)建站是一家以成都網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、成都網(wǎng)站推廣、小程序App開(kāi)發(fā)等移動(dòng)開(kāi)發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為除甲醛等眾行業(yè)中小客戶(hù)提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開(kāi)發(fā)服務(wù)。
itoa函數(shù)原型:char*itoa(int value,char*string,int radix);
功能:將任意類(lèi)型的數(shù)字轉(zhuǎn)換為字符串。在stdlib.h中與之有相反功能的函數(shù)是atoi。
nt value 被轉(zhuǎn)換的整數(shù),char *string 轉(zhuǎn)換后儲(chǔ)存的字符數(shù)組,int radix 轉(zhuǎn)換進(jìn)制數(shù),如2,8,10,16 進(jìn)制等。
擴(kuò)展資料:
方法
#includestdio.h
int?main(void)
{ int?i=0,n,a[32];
printf("請(qǐng)輸入一個(gè)十進(jìn)制整數(shù).\n");
scanf("%d",n);
while?(n0)
{a[i]=n%2;
i=i+1;
n=n/2;? }
printf("十進(jìn)制整數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)是:\n");
for(i--;i=0;i--)
printf("%d",a[i]);
printf("\n");
return?0;}
十進(jìn)制整數(shù)轉(zhuǎn)換為二進(jìn)制整數(shù)的方法:
十進(jìn)制整數(shù)轉(zhuǎn)換為二進(jìn)制整數(shù)采用"除2取余,逆序排列"法。
具體做法是:用2去除十進(jìn)制整數(shù),可以得到一個(gè)商和余數(shù);再用2去除商,又會(huì)得到一個(gè)商和余數(shù),如此進(jìn)行,直到商為零時(shí)為止,然后把先得到的余數(shù)作為二進(jìn)制數(shù)的低位有效位,后得到的余數(shù)作為二進(jìn)制數(shù)的高位有效位,依次排列起來(lái)。
求十進(jìn)制轉(zhuǎn)換二進(jìn)制C語(yǔ)言代碼代碼如下:
#include stdio.h
#define? NR (sizeof(int)*8)? // 二進(jìn)制位的個(gè)數(shù)
void deciToBin(int num); // 十進(jìn)制轉(zhuǎn)換為二進(jìn)制函數(shù)聲明
/* 主函數(shù) */
int main(void)
{
int num;
fprintf(stdout, "請(qǐng)輸入一個(gè)正整數(shù):");
/* 獲取并檢查用戶(hù)輸入 */
while (1)
{
if (fscanf(stdin, "%d", num) != 1)
{
fprintf(stderr, "輸入錯(cuò)誤!請(qǐng)重新輸入:");
while (getchar() != '\n'); // 去掉多余的非法字符
continue;
}
else if (num 0)? ? ? ? ? ? ?// 輸入的數(shù)不能為負(fù)數(shù)
{
fprintf(stderr, "請(qǐng)輸入錯(cuò)誤!請(qǐng)輸入正整數(shù):");
continue;
}
else
break;
}
fprintf(stdout, "對(duì)應(yīng)二進(jìn)制為:");
#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ù)功能:實(shí)現(xiàn)十進(jìn)制轉(zhuǎn)換為二進(jìn)制
* @參數(shù):需要轉(zhuǎn)換的十進(jìn)制整數(shù)
*/
void deciToBin(int num)
{
/* 第歸結(jié)束條件 */
if (num == 0)
{
return;
}
/* 第歸調(diào)用 */
deciToBin(num/2);
/* 逆序打印 */
fprintf(stdout, "%d", num%2);
}
擴(kuò)展資料:
使用C語(yǔ)言編程實(shí)現(xiàn)任意進(jìn)制數(shù)(2-16進(jìn)制)轉(zhuǎn)換為其他任意進(jìn)制數(shù)(2-16進(jìn)制)方法:
#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("請(qǐng)輸入待轉(zhuǎn)換數(shù)的進(jìn)制(2-16):");
do {
scanf_s("%d", B);? ? ? ?
} while (B 2 B 16);
printf("請(qǐng)輸入待轉(zhuǎn)換數(shù):");
getchar();? ? ? ?
gets_s(a);
int m = TenNum(a, B);
printf("請(qǐng)輸入需要轉(zhuǎn)成幾進(jìn)制數(shù)(2-16):");
do {
scanf_s("%d", b);
} while (B 2 B 16);
printf("%d進(jìn)制數(shù)%s轉(zhuǎn)換為%d進(jìn)制數(shù)的結(jié)果為:",B,a,b);
Numchange(m, b);
printf("\n");
system("pause");
return 0;
}
c語(yǔ)言將十進(jìn)制數(shù)轉(zhuǎn)換為16進(jìn)制的函數(shù):
#includestdio.h
main()
{
int u10;
char u16[10];
int w=0,a,b,i;
printf("請(qǐng)輸入一個(gè)數(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進(jìn)制數(shù)字為:",u10);
for(i=w-1;i=0;i--)
{
printf("%c",u16[i]);
}
printf("\n");
}
擴(kuò)展資料:
十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)方法
十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)時(shí),由于整數(shù)和小數(shù)的轉(zhuǎn)換方法不同,所以先將十進(jìn)制數(shù)的整數(shù)部分和小數(shù)部分分別轉(zhuǎn)換后,再加以合并。
1. 十進(jìn)制整數(shù)轉(zhuǎn)換為二進(jìn)制整數(shù) 十進(jìn)制整數(shù)轉(zhuǎn)換為二進(jìn)制整數(shù)采用"除2取余,逆序排列"法。具體做法是:用2去除十進(jìn)制整數(shù),可以得到一個(gè)商和余數(shù);再用2去除商,又會(huì)得到一個(gè)商和余數(shù),如此進(jìn)行,直到商為零時(shí)為止,然后把先得到的余數(shù)作為二進(jìn)制數(shù)的低位有效位,后得到的余數(shù)作為二進(jìn)制數(shù)的高位有效位,依次排列起來(lái)。
2.十進(jìn)制小數(shù)轉(zhuǎn)換為二進(jìn)制小數(shù)
十進(jìn)制小數(shù)轉(zhuǎn)換成二進(jìn)制小數(shù)采用"乘2取整,順序排列"法。具體做法是:用2乘十進(jìn)制小數(shù),可以得到積,將積的整數(shù)部分取出,再用2乘余下的小數(shù)部分,又得到一個(gè)積,再將積的整數(shù)部分取出,如此進(jìn)行,直到積中的小數(shù)部分為零,或者達(dá)到所要求的精度為止。
然后把取出的整數(shù)部分按順序排列起來(lái),先取的整數(shù)作為二進(jìn)制小數(shù)的高位有效位,后取的整數(shù)作為低位有效位。
參考資料:
百度百科-十進(jì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("輸入一個(gè)整數(shù)\n");
scanf("%d",a);
printf("輸入要轉(zhuǎn)換的進(jìn)制\n");
scanf("%d",n);
P(a,n);
return 0;}
標(biāo)題名稱(chēng):十進(jìn)制轉(zhuǎn)換函數(shù)c語(yǔ)言 十六進(jìn)制轉(zhuǎn)十進(jìn)制函數(shù)c語(yǔ)言
標(biāo)題URL:http://aaarwkj.com/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)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)