2015 ACM / ICPC 北京现场赛 I 题

构造

注意一个小坑,每条蛇的输出是要从头到尾输出的。

还要注意的是,不能开数组去模拟构造过程,然后输出,那样会TLE的。

#include <cstdio>
#include <cstring>
#include <cmath>
#include <vector>
#include <algorithm>
using namespace std; const int maxn=+;
vector<int> G[maxn];
int Find[maxn][];
int n;
int R1,C1,R2,C2;
int tot; int ans[maxn][maxn]; void f()
{
Find[][]=; Find[][]=; Find[][]=;
for(int i=;i<=;i=i+)
{
if(i%==) Find[i][]=Find[i-][]+;
else Find[i][]=Find[i-][];
} for(int i=;i<=;i=i+)
{
if(i%==) Find[i][]=Find[i-][]+;
else Find[i][]=Find[i-][];
}
} void init()
{
//清空
for(int i=;i<=n;i++) G[i].clear();
tot=; //确定左图的大小
R1=C1=(n+)/; //确定右图的大小
if(n%==){
R2=Find[n-][];
C2=Find[n-][];
}
else {
R2=Find[n][];
C2=Find[n][];
}
} void odd()
{
for(int i=;i<=n;i=i+)
{
tot++;
for(int j=;j<=tot;j++)
{
G[i].push_back(tot);
G[i].push_back(j); ans[tot][j]=i;
}
for(int j=tot-;j>=;j--)
{
G[i].push_back(j);
G[i].push_back(tot); ans[j][tot]=i;
}
}
} void even()
{
if(R1==R2)
{
int NowR=;
int NowC=; for(int i=;i<=n;i=i+)
{ //横着画
if(i%==)
{
for(int j=;j<=i/;j++)
{
G[i].push_back(NowR+);
G[i].push_back(j+C1); ans[NowR+][j+C1]=i;
} for(int j=i/;j>=;j--)
{
G[i].push_back(NowR+);
G[i].push_back(j+C1); ans[NowR+][j+C1]=i;
}
NowR=NowR+;
} //竖着画
else
{
for(int j=;j<=i/;j++)
{
G[i].push_back(j);
G[i].push_back(NowC++C1); ans[j][NowC++C1]=i;
} for(int j=i/;j>=;j--)
{
G[i].push_back(j);
G[i].push_back(NowC++C1); ans[j][NowC++C1]=i;
}
NowC=NowC+;
}
}
}
else if(R1==C2)
{
swap(R2,C2); int NowR=R2+;
int NowC=; for(int i=;i<=n;i=i+)
{
//竖着画 if(i%==)
{
for(int j=R2;j>=R2-i/+;j--)
{
G[i].push_back(j);
G[i].push_back(NowC++C1); ans[j][NowC++C1]=i;
} for(int j=R2-i/+;j<=R2;j++)
{
G[i].push_back(j);
G[i].push_back(NowC++C1); ans[j][NowC++C1]=i;
}
NowC=NowC+;
} //横着画
else
{
for(int j=;j<=i/;j++)
{
G[i].push_back(NowR-);
G[i].push_back(j+C1); ans[NowR-][j+C1]=i;
} for(int j=i/;j>=;j--)
{
G[i].push_back(NowR-);
G[i].push_back(j+C1); ans[NowR-][j+C1]=i;
}
NowR=NowR-;
}
}
}
} void print()
{
for(int i=;i<=n;i++)
{
for(int j=;j<G[i].size();j++)
{
printf("%d",G[i][j]);
if(j<G[i].size()-) printf(" ");
else printf("\n");
}
}
} int main()
{
f();
while(~scanf("%d",&n))
{
init();//初始化
odd();//左图
even();//右图
/*
for(int i=1;i<=R1;i++)
{
for(int j=1;j<=C1+C2;j++)
{
printf("%5d",ans[i][j]);
}
printf("\n");
}
*/
printf("%d %d\n",R1,C1+C2);
print();//输出
}
return ;
}

最新文章

  1. 尚硅谷-Maven笔记
  2. POJ 2229 Sumsets
  3. Eclipse配置Lifery SDK步骤与错误解决。
  4. Android中实现消息推送(JPush)
  5. 大神写的一个纯CSS圆角框,膜拜!(支持IE9一下的低版本)
  6. gcc: multiple definition of [转]
  7. 射手网字幕打包下载(73.16G)
  8. LeetCode题解——4Sum
  9. ASIHTTPRequest 编码问题
  10. ASP.NETserver控件使用之Reportviewer 报表
  11. debian install &amp; configure(2)-drivers-nvidia
  12. linux-nc命令介绍
  13. go标准库的学习-crypto/md5
  14. ext2文件系统的运行—superblock/inode/block
  15. #Leetcode# 725. Split Linked List in Parts
  16. Linux命令(二十一) 改变文件所有权 chown 和 chgrp
  17. CreateDialog 注意事项
  18. 网站url常见报错
  19. 虚拟机安装苹果系统 VMware 12安装Mac OS X 10.10
  20. Flask框架 之 上下文管理前戏

热门文章

  1. 如何查找僵尸进程并Kill之,杀不掉的要查看父进程并杀之
  2. ubuntu 软件管理
  3. utf8 文件 错误保存为gbk 中文乱码 解决方法
  4. STM32的外部中断配置及使用
  5. php5.6之后的版本使用curl以@+文件名的方式上传文件无效的解决版本
  6. 【威佐夫博奕】 betty定理 poj 1067
  7. Android Skia和2D图形系统 .
  8. Hibernate 系列教程3-单表操作
  9. eclipse背景颜色修改插件color theme
  10. 运行第一个SparkKPI程序