十进制转化为二进制问题
有一个长度为n位的二进制数串,每一位都可能是0或1。输入一个数n,输出以n为长度的二进制数串的所有可能,要求从小到大输出并输出所有位数(即使为0)。例:输入:4输出:00...
有一个长度为n位的二进制数串,每一位都可能是0或1。输入一个数n,输出以n为长度的二进制数串的所有可能,要求从小到大输出并输出所有位数(即使为0)。例:输入:4输出:0000000100100011…(后略)我的代码是:#include<stdio.h>#include<math.h>#include<stdlib.h>#include<iostream>#define N 32using namespace std;int main(){ int n, i; printf("please input n:"); scanf_s("%d", &n); int j = pow(2.0, n); int *a; a = (int*)malloc(sizeof(int)*j); free(a); for (i = 0; i < j; i++) a[i] = i; printf("0"); for (i = 0; i < j; i++) { int k, t, m = 0, b[N]; k = a[i]; for (t = 0; k > 0; t++) { b[t] = k % 2; k /= 2; } m = t; for (t = m - 1; t >= 0; t--) printf("%d", b[t]); printf("\n"); } return 0;}咋让输出结果符合题意长度为3时为001而不是1这种;或者重新编写个程序
展开
2个回答
展开全部
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<iostream>
#define N 32
using namespace std;
int main()
{
int n, i;
printf("please input n:");
scanf("%d", &n);
int j = pow(2.0, n);
int *a;
a = (int*)malloc(sizeof(int)*j);
for (i = 0; i < j; i++) a[i] = i;
for (i = 0; i < j; i++)
{
int k, t, m = 0, b[N];
k = a[i];
for (t = 0; t<n; t++)
{
b[t] = k % 2;
k /= 2;
}
m = t;
for (t = m - 1; t >= 0; t--)
printf("%d", b[t]);
printf("\n");
}
return 0;
}
追问
大神你咋改的瞬间可以了6666
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询