CodeForces - 995E Number Clicker (双向BFS)
题意:给出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)的更多相关文章
- CF995E Number Clicker (双向BFS)
题目链接(洛谷) 题目大意 给定两个数 \(u\) , \(v\) .有三种操作: \(u=u+1(mod\) \(p)\) . \(u=u+p−1(mod\) \(p)\) . \(u=u^{p−2 ...
- Number Clicker CodeForces - 995E(双向bfs)
双向bfs 注意数很大 用map来存 然后各种难受....
- Codeforces 995 E - Number Clicker
E - Number Clicker 思路:双向搜索 代码: #include<bits/stdc++.h> using namespace std; #define fi first # ...
- HDU 3085 Nightmare Ⅱ (双向BFS)
Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- Hdu1401-Solitaire(双向bfs)
Solitaire is a game played on a chessboard 8x8. The rows and columns of the chessboard are numbered ...
- UVA1601-The Morning after Halloween(双向BFS)
Problem UVA1601-The Morning after Halloween Accept: 289 Submit: 3136 Time Limit: 12000 mSec Problem ...
- 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 ...
- HDU3085(双向BFS+曼哈顿距离)题解
Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- 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. ...
随机推荐
- Switch选择语句能否作用在String【字符串】上,也就是能否这么写:Switch(一个字符串变量)?
Switch选择语句能否作用在String[字符串]上,也就是能否这么写:Switch(一个字符串变量)? 解答:不可以,只能处理int,byte,short,char,(其实是只能处理int,其它三 ...
- Android开发人员必须掌握的10 个开发工具+应该深入学习的10个开源应用项目
一.Android开发人员必须掌握的10 个开发工具 Android SDK 本身包含很多帮助开发人员设计.开发.测试和发布 Android 应用的工具,在本文中,我们将讨论 10 个最常用的工具. ...
- 将Centos的yum源更换为国内的阿里云(163)源
阿里云是最近新出的一个镜像源.得益于阿里云的高速发展,这么大的需求,肯定会推出自己的镜像源.阿里云Linux安装镜像源地址:http://mirrors.aliyun.com/ CentOS系统更换软 ...
- java锁和同步
Java 语言设计中的一大创新就是:第一个把跨平台线程模型和锁模型应用到语言中去,Java 语言包括了跨线程的关键字synchronized 和 volatile,使用关键字和java类库就能够简单的 ...
- VS2008 调试出现错误 "Unable to start debugging."
之前用的好好的调试功能,今天“F5”出现了 "Unable to start debugging." 的错误: 解决办法: 打开工程属性,选择“Debugging”,看看“Debu ...
- python3----练习题(过滑块验证)
# 导入模块 from selenium import webdriver from selenium.webdriver import ActionChains from selenium.webd ...
- MYSQL批量插入数据库实现语句性能分析【转】 批量插入!程序里面对于数据库插入的功能尽量用【异步处理+批量插入+(事务)】
假定我们的表结构如下 代码如下 CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 50 ) NOT NULL,value VA ...
- UI层复习笔记
在main文件中,UIApplicationMain函数一共做了三件事 根据第三个参数创建了一个应用程序对象 默认写nil,即创建的是UIApplication类型的对象,此对象看成是整个应用程序的一 ...
- iOS tabbar 属性
1.设置tabbar背景颜色 NSArray *controllers = [NSArray arrayWithObjects:nav_main,nav_channle,nav_me, nil]; _ ...
- RPC远程过程调用概念及实现
RPC框架学习笔记 >>什么是RPC RPC 的全称是 Remote Procedure Call 是一种进程间通信方式. 它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过 ...