c語言編程將十進制轉化為2進制可按手工轉換規則進行程序轉換。
創新互聯建站為您提適合企業的網站設計?讓您的網站在搜索引擎具有高度排名,讓您的網站具備超強的網絡競爭力!結合企業自身,進行網站設計及把握,最后結合企業文化和具體宗旨等,才能創作出一份性化解決方案。從網站策劃到成都網站建設、網站制作, 我們的網頁設計師為您提供的解決方案。
整數占四個字節,每字節8位,共32位。所以,可以定義一個32位的數組來存儲轉換結果。
循環將整數進行除2取余數,余數存儲到數組中。
當整數整除為0時,結束循環
逆序輸出數組,得到轉換結果
參考代碼:
#include stdio.h
void main()
{
int c[32],i=0,n;
scanf("%d", n) ; //輸入待轉換整數n
do {
c[i++]=n%2;
n/=2;
} while(n!=0) ;
for(i--;i=0;i--)
printf("%d",c[i] );
printf("\n");
}
void dectobin(int n,char s[],int i){
if(n==0) {
i=0;
return ;
}
else {
dectobin(n/2,s,i);
s[i]='0'+n%2;
i++;
}
}
int main( )
{
int ri,repeat;
int i,n;
scanf("%d",repeat);
for(ri=1;ri=repeat;ri++){
scanf("%d",n);
if(n==0) cout"0"endl;
char s[50];
int k=0;
dectobin(n,s,k);
s[k]='\0';
couts;
printf("\n");
}
}
還是改了函數,如果不改的話,必須使用棧,那樣更加麻煩,用遞歸簡單點
給個提醒:做人要厚道,下次再0分就不給做了哈
求十進制轉換二進制C語言代碼代碼如下:
#include stdio.h
#define? NR (sizeof(int)*8)? // 二進制位的個數
void deciToBin(int num); // 十進制轉換為二進制函數聲明
/* 主函數 */
int main(void)
{
int num;
fprintf(stdout, "請輸入一個正整數:");
/* 獲取并檢查用戶輸入 */
while (1)
{
if (fscanf(stdin, "%d", num) != 1)
{
fprintf(stderr, "輸入錯誤!請重新輸入:");
while (getchar() != '\n'); // 去掉多余的非法字符
continue;
}
else if (num 0)? ? ? ? ? ? ?// 輸入的數不能為負數
{
fprintf(stderr, "請輸入錯誤!請輸入正整數:");
continue;
}
else
break;
}
fprintf(stdout, "對應二進制為:");
#if 1 /* 方法一: 不使用遞歸 */
char bitArr[NR];
int i = -1;
/* 算法:棧的數學模型 */
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);? ? ? ?// 調用第歸函數
fputc('\n', stdout);
}
#endif
return 0;
}
/*
* @函數名:deciToBin
* @函數功能:實現十進制轉換為二進制
* @參數:需要轉換的十進制整數
*/
void deciToBin(int num)
{
/* 第歸結束條件 */
if (num == 0)
{
return;
}
/* 第歸調用 */
deciToBin(num/2);
/* 逆序打印 */
fprintf(stdout, "%d", num%2);
}
擴展資料:
使用C語言編程實現任意進制數(2-16進制)轉換為其他任意進制數(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("請輸入待轉換數的進制(2-16):");
do {
scanf_s("%d", B);? ? ? ?
} while (B 2 B 16);
printf("請輸入待轉換數:");
getchar();? ? ? ?
gets_s(a);
int m = TenNum(a, B);
printf("請輸入需要轉成幾進制數(2-16):");
do {
scanf_s("%d", b);
} while (B 2 B 16);
printf("%d進制數%s轉換為%d進制數的結果為:",B,a,b);
Numchange(m, b);
printf("\n");
system("pause");
return 0;
}
c語言中沒有二進制的格式輸出符號.
你可以用itoa函數很方便的將一個10進制int轉變成二進制字符串.
如:
int
i;
char
s[128];
scanf("%d",i);
itoa(i,
s,
2);
/*3個參數,第一個是待轉換的數,第二個是存放轉換后的字符串,第三個即需要轉換的進制*/
printf("該數轉換為二進制是:
[%s]\n",s);
補充一點,itoa函數的頭文件是stdlib.h
十進制轉二進制可以使用庫函數itoa。
itoa函數原型:char*itoa(int value,char*string,int radix);
功能:將任意類型的數字轉換為字符串。在stdlib.h中與之有相反功能的函數是atoi。
nt value 被轉換的整數,char *string 轉換后儲存的字符數組,int radix 轉換進制數,如2,8,10,16 進制等。
擴展資料:
方法
#includestdio.h
int?main(void)
{ int?i=0,n,a[32];
printf("請輸入一個十進制整數.\n");
scanf("%d",n);
while?(n0)
{a[i]=n%2;
i=i+1;
n=n/2;? }
printf("十進制整數轉換為二進制數是:\n");
for(i--;i=0;i--)
printf("%d",a[i]);
printf("\n");
return?0;}
十進制整數轉換為二進制整數的方法:
十進制整數轉換為二進制整數采用"除2取余,逆序排列"法。
具體做法是:用2去除十進制整數,可以得到一個商和余數;再用2去除商,又會得到一個商和余數,如此進行,直到商為零時為止,然后把先得到的余數作為二進制數的低位有效位,后得到的余數作為二進制數的高位有效位,依次排列起來。
1、打開visual C++ 6.0-文件-新建-文件-C++ Source File。
2、定義數組和變量:#include stdio.h#include stdlib.hvoid main(){int i, j, n, m;*定義變量i,j,n,m*/int a[16] ={0}/*定義數組a,元素初始值為0*/system("cls");/*清屏*/。
3、輸入十進制數:printf("請輸入一個十進制數(0~32767):\n");scanf("%d", n);/*輸入n的值*/。
4、計算二進制數:for (m = 0; m 15; m++)/*for循環從0到14,最高為符號位,本題始終為0*/{i = n % 2;/*取2的余數*/j = n / 2;/*取被2整除的結果*/n = j;/*將得到的商賦給變量n*/a[m] = i;/*將余數存入數組a中*/}。
5、最后運行一下看看結果,就完成了。
新聞標題:c語言十進制轉2進制函數 c語言十進制轉二進制
轉載來源:http://vcdvsql.cn/article0/doodjio.html
成都網站建設公司_創新互聯,為您提供自適應網站、手機網站建設、外貿建站、App設計、網頁設計公司、建站公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯