题意:给出u,v,p,对u可以进行三种变化: 1.u=(u+1)%p ; 2.u = (u+p-1)%p;  3.u = 模p下的逆元。问通过几步可以使u变成v,并且给出每一步的操作。

分析:朴素的bfs或dfs会超时或炸栈,考虑用双向bfs头尾同时搜。用map存每个数的访问状态和对应的操作编号,正向搜步长为正,反向搜步长为负。反向搜的时候要注意对应加减操作是反过来的。

#include<stdio.h>
#include<iostream>
#include<cstring>
#include<iostream>
#include<queue>
#include<map>
#include<string>
#include<stack>
using namespace std;
typedef long long LL;
const int maxn =;
const int INF=0x3f3f3f3f;
struct Node{
int step, but;
LL pre;
};
map<LL,Node> path;
LL u,v,p; LL fpow(LL a,LL n)
{
LL res=;
while(n){
if(n&) res =(res*a)%p;
a = a*a %p;
n>>=;
}
return res;
} void Print(LL a,LL b,int op)
{
printf("%d\n",path[a].step--path[b].step);
stack<int> S;
while(a!=u){
Node ap = path[a];
S.push(ap.but);
a = ap.pre;
}
while(!S.empty()){
int x =S.top();S.pop();
printf("%d ",x);
}
printf("%d ",op);
while(b!=v){
Node bp =path[b];
printf("%d ",bp.but);
b = bp.pre;
}
puts("");
} void BFS()
{
path.clear();
path[u]=(Node){,-,-};
path[v]=(Node){-,-,-};
queue<LL> qf,qb;
qf.push(u); qb.push(v);
while(!qf.empty()|| !qb.empty()){
if(!qf.empty()){
LL x = qf.front(); qf.pop();
Node xp = path[x];
LL next = (x+)%p;
Node np = path[next];
if(np.step==){ //未访问
path[next]= (Node){xp.step+,,x};
qf.push(next);
}
else if(np.step<){ //相遇
Print(x,next,);
return;
} next = (x+p-) %p; //op2
np = path[next];
if(np.step==){
path[next]= (Node){xp.step+,,x};
qf.push(next);
}
else if(np.step<){
Print(x,next,);
return;
} next = fpow(x,p-);
np = path[next];
if(np.step==){
path[next] = (Node){xp.step+,,x};
qf.push(next);
}
else if(np.step<){
Print(x,next,);
return;
}
} if(!qb.empty()){
LL x = qb.front(); qb.pop();
Node xp = path[x]; LL next = (x+p-)%p;
Node np = path[next];
if(!np.step){
path[next] = (Node){xp.step-,,x};
qb.push(next);
}
else if(np.step>){
Print(next,x,);
return;
} next = (x+)%p;
np = path[next];
if(!np.step){
path[next] = (Node){xp.step-,,x};
qb.push(next);
}
else if(np.step>){
Print(next,x,);
return;
} next = fpow(x,p-);
np = path[next];
if(!np.step){
path[next] = (Node){xp.step-,,x};
qb.push(next);
}
else if(np.step>){
Print(next,x,);
return;
}
}
}
} int main()
{
#ifndef ONLINE_JUDGE
freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
#endif
int N,M,tmp,T;
while(scanf("%lld %lld %lld",&u,&v,&p)==){
if(u==v){
puts("");
continue;
}
BFS();
}
return ;
}

CodeForces - 995E Number Clicker (双向BFS)的更多相关文章

  1. CF995E Number Clicker (双向BFS)

    题目链接(洛谷) 题目大意 给定两个数 \(u\) , \(v\) .有三种操作: \(u=u+1(mod\) \(p)\) . \(u=u+p−1(mod\) \(p)\) . \(u=u^{p−2 ...

  2. Number Clicker CodeForces - 995E(双向bfs)

    双向bfs  注意数很大  用map来存 然后各种难受....

  3. Codeforces 995 E - Number Clicker

    E - Number Clicker 思路:双向搜索 代码: #include<bits/stdc++.h> using namespace std; #define fi first # ...

  4. HDU 3085 Nightmare Ⅱ (双向BFS)

    Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  5. Hdu1401-Solitaire(双向bfs)

    Solitaire is a game played on a chessboard 8x8. The rows and columns of the chessboard are numbered ...

  6. UVA1601-The Morning after Halloween(双向BFS)

    Problem UVA1601-The Morning after Halloween Accept: 289 Submit: 3136 Time Limit: 12000 mSec  Problem ...

  7. Eight (HDU - 1043|POJ - 1077)(A* | 双向bfs+康拓展开)

    The 15-puzzle has been around for over 100 years; even if you don't know it by that name, you've see ...

  8. HDU3085(双向BFS+曼哈顿距离)题解

    Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  9. POJ-3131-Cubic Eight-Puzzle(双向BFS+哈希)

    Description Let's play a puzzle using eight cubes placed on a 3 × 3 board leaving one empty square. ...

随机推荐

  1. C0301 代码块{}的使用,重定向, 从文件中读取行

    #!/bin/bash # 从 /etc/fstab 中读行 File=/etc/fstab {     read line1     read line2 } < $File # {}代码块, ...

  2. zend studio 10.6.2 设置默认编码为UTF-8

    如果汉化的:窗体-->常规-->工作空间   然后再选择编码格式 如果未汉化:Window->Preferences->General->wookspace   然后再选 ...

  3. java 学习笔记--mybatis 三剑客(mybatis)

    Java项目中使用Mybatis入门程序 wanna 关注 2017.03.23 14:33* 字数 270 阅读 1243评论 0喜欢 5 MyBatis 是支持定制化 SQL.存储过程以及高级映射 ...

  4. C++ 类模板一(类模板的定义)

    //类模版语法 #include<iostream> using namespace std; /* 类模板和函数模板深入理解 1.编译器并不是把函数模板处理成能处理任何类型的函数 2.编 ...

  5. 解决PowerDesigner中DBMS设置的问题

    转自:http://blog.csdn.net/yangpeng201203/article/details/9205913 在创建物理模型时DBMS下拉框是空的,没值,以前从来没遇到过这种现象, 开 ...

  6. MFC绘图相关GDI工具对象和函数介绍

    在利用MFC进行界面编程时,除了需要熟悉各种类型控件的操作外,还会经常遇到图形绘制和显示的问题,比如时频分析界面.图像处理界面等.处理这些软件界面开发问题时,不可避免地需要用到一系列GDI工具对象和相 ...

  7. asp.net知识汇总-页面跳转Server.Transfer和Response.Redirect

    1. Server.Transfer 服务器端跳转 webform1.aspx跳转到webform2.aspx页面 webform1.aspx代码如下: protected void Page_Loa ...

  8. 微软2016校园招聘4月在线笔试 hihocoder 1289 403 Forbidden

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 Little Hi runs a web server. Sometimes he has to deny acces ...

  9. js压缩 uglify

    grunt-contrib-uglify uglify是一个文件压缩插件,项目地址:https://github.com/gruntjs/grunt-contrib-uglify 本文将以一个DEMO ...

  10. 在ChemDraw中输入千分号的方法

    很多的用户都会使用ChemDraw化学绘图工具来绘制一些化学反应的过程,但是一些化合物中有些元素所占的比例是非常小的,这个时候往往就需要千分号来显示比例.但是在ChemDraw的工具栏上只有百分号没有 ...