7、十进制数转换成二进制数

题目:十进制数转换成二进制数

适用于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");
}

同理,要表示更大的十进制数,只要改变数组容量大小即二进制数的位数即可。

发布了16 篇原创文章 · 获赞 0 · 访问量 326

猜你喜欢

转载自blog.csdn.net/NAU_LHT/article/details/104168131