十進制轉(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語言代碼代碼如下:
#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ù):
#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ù)作為低位有效位。
參考資料:
百度百科-十進制
#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)