编写程序,用递归法将一个十进制整数转换成二进制数。

 我来答
创作者b5TIJ70I1v
2019-03-16 · TA获得超过3830个赞
知道大有可为答主
回答量:3051
采纳率:27%
帮助的人:148万
展开全部
程序如下:
#include
#include
#define
N
100
char
a[N];
void
convert(int
n,int
i){
if(n>0){
a[i]=n%2;
a[i]+=48;
n/=2;i++;
convert(n,i);
}
}//十进制递归变二进制
void
main(){
long
int
n;
int
i,j,k,temp;
while(scanf("%d",&n)!=EOF){
for(i=0;i
=0;i--)printf("%c",a[i]);
printf("\n");
}
}
随着你的心d9
2010-05-12 · TA获得超过689个赞
知道小有建树答主
回答量:183
采纳率:75%
帮助的人:133万
展开全部
#!/bin/sh

while :
do
echo "input a number:['q' to quit] \c"
read inputNumber
if [ "${inputNumber}" == "q" ]
then
exit 0
fi
bc<<!
ibase=10
a=${inputNumber}
obase=2
a+0
!
done

执行结果:

input a number:['q' to quit] 1
1
input a number:['q' to quit] 2
10
input a number:['q' to quit] 3
11
input a number:['q' to quit] 4
100
input a number:['q' to quit] 5
101
input a number:['q' to quit] 6
110
input a number:['q' to quit] 7
111
input a number:['q' to quit] 8
1000
input a number:['q' to quit] 9
1001
input a number:['q' to quit] 10
1010
input a number:['q' to quit] 1024
10000000000
input a number:['q' to quit] 4096
1000000000000
input a number:['q' to quit] 123425623454625646
110110110011111101111001101011010001100011010111101101110
input a number:['q' to quit] q
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
丿_风之殇
推荐于2017-10-05
知道答主
回答量:19
采纳率:0%
帮助的人:24.3万
展开全部
程序如下:
#include<stdio.h>
#include<string.h>
#define N 100
char a[N];
void convert(int n,int i){
if(n>0){
a[i]=n%2;
a[i]+=48;
n/=2;i++;
convert(n,i);
}
}//十进制递归变二进制

void main(){
long int n;
int i,j,k,temp;
while(scanf("%d",&n)!=EOF){
for(i=0;i<N;i++)a[i]='\0';
convert(n,0);
i=N-1;
while(a[i]==NULL)i-- ;
for(;i>=0;i--)printf("%c",a[i]);
printf("\n");
}
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式