题目:十进制数转换成二进制数
适用于15及以内的十进制数:
#include<stdio.h>
void fun(int n);
int main(){
int n;
scanf("%d", &n);
fun(n);
return 0;
}
void fun(int n){
int a[4], i;
//十进制数不断除2,余数保存在数组中(容量为4的数组即4位二进制数能表示的最大数为15)
for(i=0;i<4;i++){
a[i]=n%2;
n = n/2;
}
//从后往前,遍历数组输出二进制(数组的最后一个元素是二进制的最高位)
for(i=3;i>=0;i--){
printf("%d", a[i]);
}
printf("\n");
}
改进成适用于31及以内的十进制数:
void fun(int n){
int a[5], i;
//5位二进制数能表示的最大数为31
for(i=0;i<5;i++){
a[i]=n%2;
n = n/2;
}
for(i=4;i>=0;i--){
printf("%d", a[i]);
}
printf("\n");
}
同理,要表示更大的十进制数,只要改变数组容量大小即二进制数的位数即可。