模拟。

把操作记录一下,倒着复原回去。

#pragma comment(linker, "/STACK:1024000000,1024000000")
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<iostream>
using namespace std;
typedef long long LL;
const double pi=acos(-1.0),eps=1e-;
void File()
{
freopen("D:\\in.txt","r",stdin);
freopen("D:\\out.txt","w",stdout);
}
template <class T>
inline void read(T &x)
{
char c=getchar(); x=;
while(!isdigit(c)) c=getchar();
while(isdigit(c)) {x=x*+c-''; c=getchar();}
} const int maxn=;
int n,m,q;
int ans[maxn][maxn];
int op[],r[],c[],v[]; int main()
{ scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=q;i++)
{
scanf("%d",&op[i]);
if(op[i]==) scanf("%d",&r[i]);
else if(op[i]==) scanf("%d",&c[i]);
else scanf("%d%d%d",&r[i],&c[i],&v[i]);
} for(int i=q;i>=;i--)
{
if(op[i]==) ans[r[i]][c[i]]=v[i];
else if(op[i]==)
{
for(int j=m;j>;j--)
swap(ans[r[i]][j],ans[r[i]][j-]);
}
else
{
for(int j=n;j>;j--)
swap(ans[j][c[i]],ans[j-][c[i]]);
}
} for(int i=;i<=n;i++){
for(int j=;j<=m;j++)
printf("%d ",ans[i][j]);
printf("\n");
}
return ;
}

最新文章

  1. win10使用技巧之如何打出偏僻字母
  2. 移动端js写法
  3. PHP filesystem attack vectors
  4. Pycharm使用问题# 内部Terminal
  5. js中的类GET方法
  6. MVC 直接把数据库的数据输出到view(太神奇了)
  7. android4.0访问不能网络解决方法
  8. makefile懒人版(单个文件编译)
  9. java路径中的空格问题(转)
  10. NET站点Web部署
  11. BZOJ 2431: [HAOI2009]逆序对数列( dp )
  12. eclipse不能自己主动弹出提示的解决的方法
  13. 完美解决ie浏览器location.href不刷新页面的问题,进入页面只刷新一次
  14. 201521123017 《Java程序设计》第5周学习总结
  15. SqlServer与Linq 无限递归目录树且输出层级
  16. flink1.7 checkpoint源码分析
  17. matlab学习(4) any 和cellfun用法
  18. 最小二乘法拟合非线性函数及其Matlab/Excel 实现
  19. ASP入门(十一)-Session小案例
  20. HBase + Solr Cloud实现HBase二级索引

热门文章

  1. DotNetOpenAuth搭建OAuth2.0
  2. c/c++中typedef详解
  3. python(学习之路一)
  4. PHP中的赋值-引用or传值?
  5. ASP.NET MVC中使用Ninject
  6. 项目结构的设计(iOS篇)
  7. C# 枚举常用工具方法
  8. HTTP header 介绍
  9. 支持虚拟化也开来虚拟化就是装不上HyperV的解决方法
  10. Android替换APP字体 — Typeface