题目传送门(内部题113)


输入格式

  第一行一个正整数$n$。
  接下来$n$行,每行$n$个整数,描述$C$矩阵。保证输入的是一个林先森矩阵。


输出格式

  若不可能实现,则输出一行$Impossible$;否则,输出一行一个仅包含$\{U,D,L,R\}$的字符串,表示一个$typ$参数的序列。你的序列长度不能超过$10^6$。若不需要进行任何操作,请将该序列留空。


样例

样例输入1:

2
1 2
3 0

样例输出1:

Impossible

样例输入2:

3
3 2 5
4 1 8
6 7 0

样例输出2:

UULDLU


数据范围与提示

  本题采用子任务评分。仅当你通过一个子任务下所有测试点时,你才能获得该子任务的分数。
  对于所有数据,$1\leqslant n\leqslant 50$。
  $1.$($30$分)$n\leqslant 3$。
  $2.$($30$分)$n\leqslant 10$。
  $3.$($40$分)没有特殊限制。


题解

其实就是一个大模拟。

我们考虑从小到大填,也就是先填好右下角,每一行从右到左填,从下到上依次填好每一行,直到最后两行不管。

先说怎么填好每一行。

首先,先填好每一行$3\sim n$的每一个数,方法很简单,不再赘述。

$1,2$位置需要一起填,具体方法我们可以先想办法将其变成如下图所示的情况$\downarrow$

上图中,黑色为已经填好的块和边界,橙色为准备填的两个块,这样我们只需要将$0$向左再向上移动即可移动成下图的状态$\downarrow$

剩余$1,2$两行没有填好时只需要按上面填每行的$1,2$的方法填补即可。

最后剩下左上角一个$2\times 2$的方格时判断即可。

时间复杂度:$\Theta(n^3)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int n;
int Map[55][55],sec[55][55];
bool vis[55][55];
pair<int,int> pos[10000];
int top;
char ans[10000010];
int dis(int x,int y,int x2,int y2){return abs(x-x2)+abs(y-y2);}
void U()
{
swap(Map[pos[0].first][pos[0].second],Map[pos[0].first-1][pos[0].second]);
swap(pos[0],pos[Map[pos[0].first][pos[0].second]]);ans[++top]='U';
if(top>1e6){puts("Impossible");exit(0);}
}
void D()
{
swap(Map[pos[0].first][pos[0].second],Map[pos[0].first+1][pos[0].second]);
swap(pos[0],pos[Map[pos[0].first][pos[0].second]]);ans[++top]='D';
if(top>1e6){puts("Impossible");exit(0);}
}
void L()
{
swap(Map[pos[0].first][pos[0].second],Map[pos[0].first][pos[0].second-1]);
swap(pos[0],pos[Map[pos[0].first][pos[0].second]]);ans[++top]='L';
if(top>1e6){puts("Impossible");exit(0);}
}
void R()
{
swap(Map[pos[0].first][pos[0].second],Map[pos[0].first][pos[0].second+1]);
swap(pos[0],pos[Map[pos[0].first][pos[0].second]]);ans[++top]='R';
if(top>1e6){puts("Impossible");exit(0);}
}
int judge(int x,int y)
{
if(pos[0]==make_pair(x,y+1))return 1;
if(pos[0]==make_pair(x,y-1))return 2;
if(pos[0]==make_pair(x-1,y))return 3;
if(pos[0]==make_pair(x+1,y))return 4;
return 0;
}
void change(int x,int y)
{
while(1)
{
if(judge(x,y))break;
int flag=0;
if(pos[0].first-1==x&&pos[0].second==y)goto nxt1;
if(pos[0].first>1&&dis(x,y,pos[0].first,pos[0].second)>dis(x,y,pos[0].first-1,pos[0].second)&&!vis[pos[0].first-1][pos[0].second]){U();flag=1;}
nxt1:;
if(pos[0].first+1==x&&pos[0].second==y)goto nxt2;
if(pos[0].first<n&&dis(x,y,pos[0].first,pos[0].second)>dis(x,y,pos[0].first+1,pos[0].second)&&!vis[pos[0].first+1][pos[0].second]){D();flag=1;}
nxt2:;
if(pos[0].first==x&&pos[0].second-1==y)goto nxt3;
if(pos[0].second>1&&dis(x,y,pos[0].first,pos[0].second)>dis(x,y,pos[0].first,pos[0].second-1)&&!vis[pos[0].first][pos[0].second-1]){L();flag=1;}
nxt3:;
if(pos[0].first==x&&pos[0].second+1==y)goto nxt4;
if(pos[0].second<n&&dis(x,y,pos[0].first,pos[0].second)>dis(x,y,pos[0].first,pos[0].second+1)&&!vis[pos[0].first][pos[0].second+1]){R();flag=1;}
nxt4:;
if(!flag)break;
}
}
void move(int k,int x,int y)
{
int opt=judge(x,y);
switch(k)
{
case 1:
if(opt==1){U();L();D();}
if(opt==2){U();R();D();}
if(opt==3)D();
if(opt==4)
{
if(y>1){L();U();U();R();D();}
else{R();U();U();L();D();}
}
break;
case 2:
if(opt==1)
{
if(vis[x+1][y+1]){U();L();D();D();R();U();L();U();R();D();D();L();U();}
else{D();L();U();}
}
if(opt==2){D();R();U();}
if(opt==3)
{
if(y<n){R();D();}
else{L();D();D();R();U();}
}
if(opt==4)U();
break;
case 3:
if(opt==1){U();L();L();D();R();}
if(opt==2)R();
if(opt==3){L();D();R();}
if(opt==4){L();U();R();}
break;
case 4:
if(opt==1)L();
if(opt==2)
{
if(x>1){U();R();R();D();L();}
else
{
if(vis[x+1][y+1]){R();D();R();U();L();D();R();U();L();L();D();R();R();U();L();}
else{D();R();R();U();L();}
}
}
if(opt==3){R();D();L();}
if(opt==4)
{
if(vis[x+1][y+1]){L();U();}
else{R();U();L();}
}
break;
}
}
void move(int x,int y)
{
int res=sec[x][y];
while(pos[res]!=make_pair(x,y))
{
bool flag=0;
if(pos[res].first>1&&dis(x,y,pos[res].first,pos[res].second)>dis(x,y,pos[res].first-1,pos[res].second)&&!vis[pos[res].first-1][pos[res].second])
{change(pos[res].first,pos[res].second);move(1,pos[res].first,pos[res].second);flag=1;}
if(pos[res].first<n&&dis(x,y,pos[res].first,pos[res].second)>dis(x,y,pos[res].first+1,pos[res].second)&&!vis[pos[res].first+1][pos[res].second])
{change(pos[res].first,pos[res].second);move(2,pos[res].first,pos[res].second);flag=1;}
if(pos[res].second>1&&dis(x,y,pos[res].first,pos[res].second)>dis(x,y,pos[res].first,pos[res].second-1)&&!vis[pos[res].first][pos[res].second-1])
{change(pos[res].first,pos[res].second);move(3,pos[res].first,pos[res].second);flag=1;}
if(pos[res].second<n&&dis(x,y,pos[res].first,pos[res].second)>dis(x,y,pos[res].first,pos[res].second+1)&&!vis[pos[res].first][pos[res].second+1])
{change(pos[res].first,pos[res].second);move(4,pos[res].first,pos[res].second);flag=1;}
if(!flag)break;
}
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
scanf("%d",&Map[i][j]);sec[i][j]=(i-1)*n+j-1;
pos[Map[i][j]]=make_pair(i,j);
}
for(int i=n;i>2;i--)
for(int j=n;j;j--)
{
move(i,j);
vis[i][j]=1;
}
for(int j=n;j>1;j--)
{
move(2,j);vis[2][j]=1;
move(1,j);vis[1][j]=1;
}
if(pos[0]!=make_pair(1,1)){swap(Map[1][1],Map[2][1]);ans[++top]='U';}
printf("%s",ans+1);
return 0;
}

rp++

[CSP-S模拟测试]:线性代数(模拟)的更多相关文章

  1. 模拟测试—moq:简单一两句

    在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...

  2. csp-s模拟测试98

    csp-s模拟测试98 $T1$??不是我吹我轻松手玩20*20.$T2$装鸭好像挺可做?$T3$性质数据挺多提示很明显? $One$ $Hour$ $Later$ 这$T1$什么傻逼题真$jb$难调 ...

  3. Android单元测试与模拟测试详解

    测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...

  4. [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)

    目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...

  5. 安装nginx python uwsgi环境 以及模拟测试

    uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...

  6. 利用Python中的mock库对Python代码进行模拟测试

    这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下     ...

  7. 转 C#实现PID控制的模拟测试和曲线绘图

    C#实现PID控制的模拟测试和曲线绘图   本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...

  8. Mockito:一个强大的用于Java开发的模拟测试框架

    https://blog.csdn.net/zhoudaxia/article/details/33056093 介绍 本文将介绍模拟测试框架Mockito的一些基础概念, 介绍该框架的优点,讲解应用 ...

  9. NOIP模拟测试1(2017081501)

    好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...

随机推荐

  1. USB fuzzing

    简介 最近看一些USB fuzzing方面的东西,总结一下.主要是软件方面的工作. vUSBf 文章在这里:https://www.blackhat.com/docs/eu-14/materials/ ...

  2. java执行bat代码

    java执行bat代码.txt public static void runbat(String path,String filename) { String cmd = "cmd /c s ...

  3. 二维数组中的查找——牛客剑指offer

    题目描述: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整 ...

  4. Dubbo从入门到实战视频教程

    Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring框架无缝集成.这里整理了一套关于dubbo的视频教程分享给大家,包 ...

  5. Centos7:mysql5.6安装,配置及使用(RPM方式)

    1.首先安装好jdk环境,本机所用环境为jdk1.8 2.卸载MariaDB(Centos7自带)与Mysql 2.1卸载:MariaDB #rpm -qa | grep -i mariadb //查 ...

  6. 无法连接asp.net development server

    我的电脑重装了,在此之前,是可以进行调试的.并且将该解决方案拷到其他机器上能正常打开.并且正常调试.今天刚打开项目调试就提示“无法连接asp.net development server”,后来发现是 ...

  7. Exited too quickly (process log may have details)-配置问题

    在配置supervisor的时候,提示Exited too quickly (process log may have details),这个时候一脸懵逼,啥回事,执行太快了???

  8. Js 将图片的绝对路径转换为base64编码(3)

    图片文件改变一方法:$('#file').change(function(){var oFReader = new FileReader();oFReader.readAsDataURL(this.f ...

  9. kafka核心原理总结

    新霸哥发现在新的技术发展时代,消息中间件也越来越受重视,很多的企业在招聘的过程中着重强调能够熟练使用消息中间件,所有做为一个软件开发爱好者,新霸哥在此提醒广大的软件开发朋友有时间多学习. 消息中间件利 ...

  10. Linux驱动开发之LED驱动

    首先讲下字符设备控制技术 : 大部分驱动程序除了需要提供读写设备的能力外,还需要具备控制设备的能力.比如: 改变波特率. 在用户空间,使用ioctl系统调用来控制设备,原型如下:int ioctl(i ...