c语言进制转换,想问下这个算法是什么原理

voidchange(intx,intr){if(x!=0){change(x/r,r);printf("%d",x%r);}}main(){intx,r;printf(... void change(int x,int r)
{
if(x!=0)
{ change(x/r,r);
printf("%d",x%r);
}
}
main()
{int x,r;
printf("\n input x and r:");
scanf("%d%d",&x,&r);
change(x,r);
}
展开
 我来答
White_MouseYBZ
2019-01-02 · TA获得超过4万个赞
知道大有可为答主
回答量:2.1万
采纳率:82%
帮助的人:6616万
展开全部
这就是“用模除,返回取余数”的递归调用函数实现。比如x是15,r是2,则——
15/2==7-->7/2==3-->3/2==1-->1/2==0,然后由printf输出——
1%2==1
3%2==1
7%2==1
15%2==1-->递归完成,所以打在屏幕上就是1111,也就是15的二进制是1111。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式