关于C++的题目

任意给定一些自然数N,以0为停止输入,寻找M,要求M是N的倍数,且它的所有各位数都是由0或1组成,要求M尽可能小,例如:输入:N=3N=31N=0输出:M=3*37=11... 任意给定一些自然数N,以0为停止输入,寻找M,要求M是N的倍数,且它的所有各位数都是由0或1组成,要求M尽可能小,
例如:
输入:
N=3
N=31
N=0
输出:
M=3*37=111
M=31*3581=111011
展开
 我来答
匿名用户
2010-08-09
展开全部
#include <iostream>
#include <cstdlib>

using namespace std;

//此函数将二进制数转换为字串再回转为十进制数
int BinToDec(int x)
{
char buf[8192];
itoa(x,buf,2);
return atoi(buf);
}

//此函数判断能否整除,通过参数返回商
bool CanDiv(int m,int n,int& d)
{
if(m%n == 0)
{
d = m/n;
return true;
}
return false;
}

//此函数生成符合规格的输出
void Output(int n,int d,int m)
{
cout<<"M="<<n<<"*"<<d<<"="<<m<<endl;
}

int main()
{
int n;
while(cin>>n && n!=0)
{
int binm = 1;
int d = 0;
while(d == 0)
{
int m = BinToDec(binm);
if(CanDiv(m,n,d))
{
Output(n,d,m);
break;
}
++binm;
}
}
return 0;
}

//编译器弹出警告说“楼主给的分太少了”
--
2022-12-05 广告
图形化编程简单理解为用积木块形式编程,scratch和python也是其中的一种,属于入门级编程,以其简单生动的画面获得无数学生的喜爱,深圳市创客火科技有限公司是一家做教育无人机的公司,旗下有编程无人机,积木无人机及室内外编队,每款飞机含有... 点击进入详情页
本回答由--提供
fantacywall
2010-08-09 · TA获得超过333个赞
知道小有建树答主
回答量:329
采纳率:0%
帮助的人:269万
展开全部
1.从0开始,枚举各个位都是1或0的数
2.判断是否是N的倍数
3.是则停止,否则回到1继续执行。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式