poj1426 Find The Multiple
来源:互联网 发布:立式数控车床编程 编辑:程序博客网 时间:2024/05/18 02:06
Memory Limit: 10000KTotal Submissions: 24082
Accepted: 9981
Special Judge
Description
Input
Output
Sample Input
26190
Sample Output
10100100100100100100111111111111111111
设6的 ”01十进制倍数” 为k,那么必有k%6 = 0
现在就是要用BFS求k值
1、先搜索k的最高位,最高位必为1,则此时k=1,但1%6 =1 != 0
因此k=1不是所求,存储余数 1
2、搜索下一位,下一位可能为0,即 k*10+0,此时k=10,那么k%6=4
可能为1,即 k*10+1,此时k=11,那么k%6=5
由于余数均不为0,即k=10与k=11均不是所求
3、继续搜索第三位,此时有四种可能了:
对于k=10,下一位可能为0,即 k*10+0,此时k=100,那么k%6=4
下一位可能为1,即 k*10+1,此时k=101,那么k%6=5
对于k=11,下一位可能为0,即 k*10+0,此时k=110,那么k%6=2
下一位可能为1,即 k*10+1,此时k=111,那么k%6=3
由于余数均不为0,即k=100,k=101,k=110,k=111均不是所求
4、继续搜索第四位,此时有八种可能了:
对于k=100,下一位可能为0,即 k*10+0,此时k=1000,那么k%6=4
下一位可能为1,即 k*10+1,此时k=1001,那么k%6=5
对于k=101,下一位可能为0,即 k*10+0,此时k=1010,那么k%6=2
下一位可能为1,即 k*10+1,此时k=1011,那么k%6=3
对于k=110,下一位可能为0,即 k*10+0,此时k=1100,那么k%6=2
下一位可能为1,即 k*10+1,此时k=1101,那么k%6=3
对于k=111,下一位可能为0,即 k*10+0,此时k=1110,那么k%6=0
下一位可能为1,即 k*10+1,此时k=1111,那么k%6=1
我们发现k=1110时,k%6=0,即1110就是所求的倍数
因此:每多一位数:就会多两个数:a. n*10+0; b.n*10+1
代码:
#include<stdio.h>#include<string.h>long long que[10000000];void bfs(int n){long long head=1,tail=1;que[tail++]=1;while(head<tail){long long temp=que[head++];if(temp%n==0){printf("%lld\n",temp);return;}que[tail++]=temp*10;que[tail++]=temp*10+1;}return;}int main(){int n;while(scanf("%d",&n)&&n){bfs(n);}return 0;}
- POJ1426 Find The Multiple
- poj1426 Find The Multiple
- poj1426 - Find The Multiple
- POJ1426 Find The Multiple
- POJ1426-Find The Multiple
- poj1426 Find The Multiple
- poj1426-Find The Multiple
- POJ1426 Find the multiple
- POJ1426-Find The Multiple
- POJ1426 Find The Multiple
- poj1426 Find The Multiple
- Find The Multiple poj1426
- poj1426 find the multiple
- POJ1426 - Find The Multiple
- poj1426 Find The Multiple
- poj1426 Find The Multiple
- poj1426: Find the Multiple
- POJ1426 Find The Multiple
- Boost基础例子
- Servlet API 中文版
- 阿里云服务器的MySQL莫名其妙的挂了 之 优化篇
- 隐马尔可夫模型Hidden Markov Model
- 容易混淆的知识点
- poj1426 Find The Multiple
- 值得推荐的C/C++框架和库 (真的很强大)
- View滚动帮助类ViewDragHelper解析
- %-3d在C语言中的含义是什么?
- poj3260&&hdu3591(多重背包+完全背包)
- 2016寒假训练——字典树
- 安卓图看清安卓
- 【Data Algorithms_Recipes for Scaling up with Hadoop and Spark】Chapter1 Secondary Sort
- 更好的设计数据库还有就是数据库语句优化~~(主要是mysql)