(BFS)poj1465-Multiple
题意可理解为我们有一些给定的元素,要用它们组成数,如果一个长度(x)所有组成的数都不是给定的另一个数(n)的倍数,并且长度为x的数中有模n的不同于长度小于x的数模n的数,那么继续延长这个数的长度。这样进行到无法进行下去时,就是要输出0的情况,中途如果找到了n的倍数,就直接返回输出。题目比较关键的是我们只需关注模n意义下的情况,这样就省略了很多细枝末节没有影响的数,并且有效的控制了数的大小,使之在我们可以接受的范围内。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n,m,digit[],an;//digit数组用于储存题目中可以出现的数(因为都是个位数,所以大小设为10)
struct node
{
int yu;//这个数模n的余数
int digit;//这位的数码
int pre;//这一位前一位的数
}q[];//建立一个结构体,方便操作
bool flag[];//通过bool数组记录某一个余数是否出现过
int bfs()
{
memset(flag,,sizeof(flag));
int front=,tail=;
q[front].yu=;
q[front].pre=-;//将第一个的pre初始化为不可能取得的数,进行后面的判断
q[front].digit=;
while(front<tail)//继续进行的条件
{
node p=q[front];
int r=p.yu;//之前的余数
for(int i=;i<m;i++)
{
int nr=(*r+digit[i])%n;//新的余数
if(!flag[nr]&&(p.pre!=-||digit[i]!=))//如果没有出现过这个余数,并且满足不是第一位或这一位是0条件之一(因为往后不可以出现0,只是加0不改变余数)
{
flag[nr]=true;
p.pre=front;
p.digit=digit[i];
p.yu=nr;
q[tail++]=p;
if(nr==)
return tail-;
}
}
front++;
}
return -;
}
void print(int x)//比较巧妙的输出方式,学习了
{
if(x>)
{
print(q[x].pre);
printf("%d",q[x].digit);
}
}
int main()
{
while(scanf("%d",&n)==)
{
scanf("%d",&m);
for(int i=;i<m;i++)
scanf("%d",&digit[i]);
if(n==)//0要单独讨论一下
{printf("0\n");
continue;}
sort(digit,digit+m);
int an=bfs();
if(an==-)
printf("0\n");
else
{print(an);
puts("");}
}
return ;
}
(BFS)poj1465-Multiple的更多相关文章
- POJ.1426 Find The Multiple (BFS)
		POJ.1426 Find The Multiple (BFS) 题意分析 给出一个数字n,求出一个由01组成的十进制数,并且是n的倍数. 思路就是从1开始,枚举下一位,因为下一位只能是0或1,故这个 ... 
- 深搜(DFS)广搜(BFS)详解
		图的深搜与广搜 一.介绍: p { margin-bottom: 0.25cm; direction: ltr; line-height: 120%; text-align: justify; orp ... 
- 【算法导论】图的广度优先搜索遍历(BFS)
		图的存储方法:邻接矩阵.邻接表 例如:有一个图如下所示(该图也作为程序的实例): 则上图用邻接矩阵可以表示为: 用邻接表可以表示如下: 邻接矩阵可以很容易的用二维数组表示,下面主要看看怎样构成邻接表: ... 
- 深度优先搜索(DFS)与广度优先搜索(BFS)的Java实现
		1.基础部分 在图中实现最基本的操作之一就是搜索从一个指定顶点可以到达哪些顶点,比如从武汉出发的高铁可以到达哪些城市,一些城市可以直达,一些城市不能直达.现在有一份全国高铁模拟图,要从某个城市(顶点) ... 
- 【BZOJ5492】[HNOI2019]校园旅行(bfs)
		[HNOI2019]校园旅行(bfs) 题面 洛谷 题解 首先考虑暴力做法怎么做. 把所有可行的二元组全部丢进队列里,每次两个点分别向两侧拓展一个同色点,然后更新可行的情况. 这样子的复杂度是\(O( ... 
- 深度优先搜索(DFS)和广度优先搜索(BFS)
		深度优先搜索(DFS) 广度优先搜索(BFS) 1.介绍 广度优先搜索(BFS)是图的另一种遍历方式,与DFS相对,是以广度优先进行搜索.简言之就是先访问图的顶点,然后广度优先访问其邻接点,然后再依次 ... 
- 图的 储存 深度优先(DFS)广度优先(BFS)遍历
		图遍历的概念: 从图中某顶点出发访遍图中每个顶点,且每个顶点仅访问一次,此过程称为图的遍历(Traversing Graph).图的遍历算法是求解图的连通性问题.拓扑排序和求关键路径等算法的基础.图的 ... 
- 数据结构与算法之PHP用邻接表、邻接矩阵实现图的广度优先遍历(BFS)
		一.基本思想 1)从图中的某个顶点V出发访问并记录: 2)依次访问V的所有邻接顶点: 3)分别从这些邻接点出发,依次访问它们的未被访问过的邻接点,直到图中所有已被访问过的顶点的邻接点都被访问到. 4) ... 
- 层层递进——宽度优先搜索(BFS)
		问题引入 我们接着上次“解救小哈”的问题继续探索,不过这次是用宽度优先搜索(BFS). 注:问题来源可以点击这里 http://www.cnblogs.com/OctoptusLian/p/74296 ... 
- HDU.2612 Find a way (BFS)
		HDU.2612 Find a way (BFS) 题意分析 圣诞节要到了,坤神和瑞瑞这对基佬想一起去召唤师大峡谷开开车.百度地图一下,发现周围的召唤师大峡谷还不少,这对基佬纠结着,该去哪一个...坤 ... 
随机推荐
- Ugly Number
			public class Solution { public bool IsUgly(int num) { ) return false; ) return true; *==num){ num = ... 
- Linux多节点互信配置
			SSH互信设置步骤: 1. 每个节点上分别生成自己的公钥和私钥 2. 将各节点的公钥文件汇总到一个总的认证文件authorized_keys中 3. 将这个包含了所有节点公钥的认证文件au ... 
- CentOS 更改yum源与更新系统
			FROM:http://www.cnblogs.com/lightnear/archive/2012/10/03/2710952.html [1] 首先备份/etc/yum.repos.d/CentO ... 
- [课程设计]Scrum 2.6 多鱼点餐系统开发进度(下单一览页面-菜式添加功能实现)
			Scrum 2.6 多鱼点餐系统开发进度 (下单一览页面-菜式添加功能实现) 1.团队名称:重案组 2.团队目标:长期经营,积累客户充分准备,伺机而行 3.团队口号:矢志不渝,追求完美 4.团队选题 ... 
- 【web必知必会】——图解HTTP(上)
			本篇总结关于http的相关知识,主要内容参考如下导图: 主要讲解的内容有: 1 URL与URI的区别. 2 请求报文与相应报文的内容. 3 GET与POST的区别. 4 http的cookie.持久化 ... 
- js中的什么时候需要用new来实例化?
			有人说js中函数和类就是一个概念,请问:1 为什么我们在大多数情况下没有用new来实例化一个类(函数),如下 JavaScript code 1 2 3 4 5 6 7 <script> ... 
- RCP:如何移除Search对话框中不需要的项
			前言 很久没写文章了,准备写一系列关于Eclipse RCP /Plugin的文章. 这些文章都是trouble shooting性质的,不准备写的很细,当你碰到这样的问题,google到时,能帮你把 ... 
- CRM系统简析
			寄语: 简单阐述一下对CRM系统应用的理解,此内容参考网上资料所整理. CRM是Customer Relationship Management的缩写,简称客户关系管理. CRM系统可以从三个方面来分 ... 
- wifipineapple使用教程
			1.把开关拨到右边 如果有灯亮说明有电 4个灯全亮说明电量是满的 以此类推 如果一个也不亮说明没电了需要用充电器充电 2.把开关拨到左边打开wifi的开关 会开启一个wifi大概一分钟左右会有wif ... 
- SQL2008游标
			最近让写一个自动生成数据的存储过程,其中会遍历表中数据并做出相应处理,因为数据量不算太大所以使用到了游标,初识游标遇到几个小问题,所以来和大家一起分享一下: 使用游标的五个步骤: 1.声明游标 语法: ... 
