POJ
来源:互联网 发布:it was not until 编辑:程序博客网 时间:2024/06/07 01:56
题目链接:http://poj.org/problem?id=1426点击打开链接
Find The Multiple
Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 33048 Accepted: 13830 Special Judge
Description
Given a positive integer n, write a program to find out a nonzero multiple m of n whose decimal representation contains only the digits 0 and 1. You may assume that n is not greater than 200 and there is a corresponding m containing no more than 100 decimal digits.
Input
The input file may contain multiple test cases. Each line contains a value of n (1 <= n <= 200). A line containing a zero terminates the input.
Output
For each value of n in the input print a line containing the corresponding value of m. The decimal representation of m must not contain more than 100 digits. If there are multiple solutions for a given value of n, any one of them is acceptable.
Sample Input
26190
Sample Output
10100100100100100100111111111111111111
Source
Dhaka 2002
题意迷人
讲的是给你一个数 你要找一个十进制的数 只能由0和1组成
然后这个十进制的数要能整除这个给的数
分析过程:
1.先创立一个数为1 (因为第一个数不为0)将他入队
2.每次从队中取出首元素进行判断 然后就是*10与(*10+1)的两个方向的广搜
3.然后计算 当前这个数两个方向的值 与给出数的余数 如果不为0 就看这个余数是否被标记过 如果标记过就跳过 没有就标记 然后入队 重复2 直到队列为空或发现余数为0
这样的标记化需要注意要记录每个操作 用vector的赋值可以快速完成
这里将1记为*10
将2记为+1;(因此(*10+1)1和2的操作都有记录)
最后根据记录的操作次数进行计算即可
此时应该也是保证所计算的数为最小的
#include <iostream>#include <queue>#include <stdio.h>#include <stdlib.h>#include <stack>#include <limits.h>#include <string>#include <string.h>#include <vector>#include <set>#include <map>#include <algorithm>#include <math.h>using namespace std;int main(){ int n=0; while(~scanf("%d",&n)&&n) { int book[n+n]; for(int i=0;i<=n+n;i++) book[i]=0; vector<int > s[n+1]; vector<int > ss; int mid=1; queue <int > q; while(!q.empty()) q.pop(); for(int i=0;i<n+1;i++) s[i].clear(); ss.clear(); q.push(1); while(!q.empty()) { int mid=q.front(); q.pop(); ss=s[mid]; if(mid==0) { break; } if(!book[mid*10%n]) { book[mid*10%n]=1; s[mid*10%n]=ss; s[mid*10%n].push_back(1); q.push(mid*10%n); } if(!book[(mid*10+1)%n]) { book[(mid*10+1)%n]=1; s[(mid*10+1)%n]=ss; s[(mid*10+1)%n].push_back(1); s[(mid*10+1)%n].push_back(2); q.push((mid*10+1)%n); } } long long int ans=1; for(int i=0;i<ss.size();i++) { if(ss[i]==1) ans*=10; else ans+=1; } cout << ans<< endl; }}
阅读全文
0 0
- POJ
- poj
- POJ
- POJ
- poj
- poj
- POJ
- POJ
- poj
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- NYOJ 448 寻找最大数
- java abstract意义:
- Ubuntu16.04开机死循环
- hdu 5358 First One [枚举+尺取法]
- crontab笔记整理
- POJ
- for循环数组冒泡排序
- AB1601读触摸芯片ASC0106的IIC波形图
- php——记中文验证码
- 机器学习实战--KNN算法
- zTree模糊搜索
- react webpack打包后怎么调试
- HDU 1010 Tempter of the Bone(深搜+剪枝)
- HDU 1028 Ignatius and the Princess III (母函数 , DP)