今天用C语言来实现十进制到二进制的基本转换
以下是对基本变量的定义
以下是对主要思想的代码实现
以下是对最后打印数组,生成二进制数的实现
以下是整体代码的实现,如果觉得有帮助的话,记得点赞哟~
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(){
int num = 0;
printf("请输入一个数:");
scanf("%d", &num);
int arr[32] = {0};//用一个长度为32的数组接收最后的二进制数,里面的0是为数组设置初始值
int index = 0;//用来定义数组的下标
arr[index] = num % 2;//先获取输入数字的第一个二进制位
index++;//下标下移一位
while (1){//使用while循环来获取剩下的二进制位
/*十进制转换为二进制思想:1.对十进制数进行除以2的操作
2.对所获得的商进行取余的操作,所获得的数就是二进制每一位
3.当num<2时,即num除以二不会再有大于1的数字,num%2必为0时
此时说明num已经完全转换位二进制数,则跳出循环*/
num = num / 2;
arr[index] = num % 2;
index++;
if (num < 2){
break;
}
}
int sz = sizeof(arr) / sizeof(arr[0]);//此为获取数组的长度,总的字节长的大小/单个元素的字节大小
//以下对数组的倒序遍历,因为arr[0]存储的是二进制位的第一位,以此内推,所以采用数组的倒序遍历
for (int i = sz - 1; i >= 0; i--){
printf("%d", arr[i]);
}
printf("\n");//进行换行操作
return 0;
}