首页 > 其他 > 详细

poj 1426 Find The Multiple

时间:2014-07-13 16:36:15      阅读:329      评论:0      收藏:0      [点我收藏+]

题意为求出只由0,1组成的并且是所给数倍数的数,

广搜。。

因为首位不能为0,因此必为1;所以搜索的下一层为上一层的10倍和10倍加1;

#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
__int64 s[9999999];
__int64 r;
void show(int q)
{
	int i,j;
	s[0]=1;
	j=0;
	i=0;
	while(i>=j)
	{
		r=s[j];
		if(r%q==0)
		{
			printf("%I64d\n",r);
			return ;
		}
		r=r*10;
		s[++i]=r;
		r=r+1;
		s[++i]=r;
		j++;
	}
}

int main()
{
	int a;
	while(scanf("%d",&a)&&a)
		show(a);
	return 0;
}
本题用栈的话会出现Memory Limit Exceeded。。


poj 1426 Find The Multiple,布布扣,bubuko.com

poj 1426 Find The Multiple

原文:http://blog.csdn.net/asuxiexie/article/details/37728777

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!