C语言10进位转化2进位。求大神啊,初学者什么都不会啊真是纠结,果然女生学这个就是作死TAT

1.函数原型: void decimalToBinary (int num);
2.把十进位数是1023以下的自然数转化成二进制的数值
3.如果不符合[1.1023]该程序结束,用return
4.化成二进制时0000 0000 0000 0000 每四位一个空格显示

程序正常施行显示
请输入一个十进位的数字: 27
0000 0000 0001 1011
请输入一个十进位的数字: 1024
不是正确的自然数

作业不是中文的,翻译的很奇怪,求大神啊解救

#include <stdlib.h>
#include <stdio.h>
#include <math.h>

#define BINARY_LEN 16

void decimalToBinary (int num)
{
    int i;
    if(num == -1)
        return;

    if (num > 1023 || num < 0)
    {
        printf("不是正确的自然数\n");
        return ;
    } 

    for(i = (BINARY_LEN - 1); i >= 0; --i)
    {
        //if ((BINARY_LEN - i - 1) % 4 == 0)
        if ((i+1) % 4 == 0 && i != 15)
            printf(" ");

        printf("%d", (num & (int)pow(2, i)) >> i); 
    }   
    printf("\n");   
}

int main(void)  //测试 
{
    int inputNum;
    for(;;)
    {
        printf("请输入1~1023的自然数,输入-1表示退出测试:");      
        scanf("%d", &inputNum); 
        if (inputNum == -1)
            return 1;
        else
            decimalToBinary(inputNum);  
    }

    getchar();  //防止闪退 
}
 #include<stdio.h>
main()
{
int i,n,k,x[10];
scanf("%d",&n);
for(i=0;n!=0;i++)// 判断条件 n!=0
{
x[i]=n%2;
n=n/2;
}
for(k=i-1;k!=(-1);k--)// 判断条件 k!=-1
printf("%d",x[k]);// 输出x[k],不是x[i]
}

#include main() { int i,n,k,x[10]; scanf("%d",&n); for(i=0;n!=0;i++)// 判断条件 n!=0 { x[i]=n%2; n=n/2; } for(k=i-1;k!=(-1);k--)// 判断条件 k!=-1 printf("%d",x[k]);// 输出x[k],不是x[i] }
然后对输入的数据进行范围的判断,不是1~1023的时候就return 0;就更好了

首先想想如果手写转换,你会怎么办?然后把你的思想变成程序,使得电脑向你那样思考

http://www.xuebuyuan.com/zh-tw/1604215.html还是得自己思考

还是得自己思考啊……

除基逆取余发…………

#include
#include
#include

#define BINARY_LEN 16

void decimalToBinary (int num)
{
int i;
if(num == -1)
return;

if (num > 1023 || num < 0)
{
    printf("不是正确的自然数\n");
    return ;
} 

for(i = (BINARY_LEN - 1); i >= 0; --i)
{
    //if ((BINARY_LEN - i - 1) % 4 == 0)
    if ((i+1) % 4 == 0 && i != 15)
        printf(" ");

    printf("%d", (num & (int)pow(2, i)) >> i); 
}   
printf("\n");   

}

int main(void) //测试
{
int inputNum;
for(;;)
{
printf("请输入1~1023的自然数,输入-1表示退出测试:");

scanf("%d", &inputNum);
if (inputNum == -1)
return 1;
else
decimalToBinary(inputNum);

}

getchar();  //防止闪退 

}


如果强调计算过程,就用一楼的办法
如果只是为了显示的话可以用这个,因为在计算机内部,整数就是用二进制存的

 void DecimalToBinary(int num)
{//从第12位开始,逐位给它打印出来
    int i = 11, j = 1;
    while(i >= 0)
    {
        printf("%d", (num>>i) & 0x01);
        if(0 == (j%4))
        {
            printf(" ");
        }
        j++;
        i--;
    }
}