【hihocoder 1257 Snake Carpet】构造

简介: 2015北京区域赛现场赛第4题。 题面:http://media.hihocoder.com/contests/icpcbeijing2015/problems.pdf OJ链接:http://hihocoder.com/problemset/problem/1257 题意:长度依次为1到N的N条蛇,平铺在一个地毯上,互不相交,要求每条长度为奇数(偶数)的蛇恰好有奇数(偶数)个拐点,1、2除外。

2015北京区域赛现场赛第4题。

题面:http://media.hihocoder.com/contests/icpcbeijing2015/problems.pdf

OJ链接:http://hihocoder.com/problemset/problem/1257

题意:长度依次为1到N的N条蛇,平铺在一个地毯上,互不相交,要求每条长度为奇数(偶数)的蛇恰好有奇数(偶数)个拐点,1、2除外。求可行的构造方案。

我的构造方法如下:

奇偶数分开,奇数始终保持L型向外扩展,偶数保持两行(列)和已有的块拼接。

注意偶数部分每隔2组进行一次90度的旋转,代码体现为判N是否能被4整除。

 1 #include <cstdio>
 2 using namespace std;
 3 int n;
 4 int H, W;
 5 
 6 void printOdd(int x, int y){
 7     printf("%d %d ", x, y);
 8 }
 9 
10 void printEven(int x, int y){
11     printf("%d %d ", x, y+H);
12 }
13 
14 int main(){
15     while(~scanf("%d", &n)){
16         H = (n+1)/2;
17         W = n&1 ? n : n+1;
18         printf("%d %d\n", H, W);
19         for(int i=1; i<=n; i++){
20             if(i&1){
21                 int x = H, y = H - i/2;
22                 while(x > y){
23                     printOdd(x, y);
24                     x--;
25                 }
26                 printOdd(x, y);
27                 y++;
28                 while(y <= H){
29                     printOdd(x, y);
30                     y++;
31                 }
32             }else{
33                 if(n%4==0 || (n+1)%4==0){
34                     int len = i/2;
35                     if(i%4 == 0){
36                         int x = H, y = i/2;
37                         while(x > H - len + 1){
38                             printEven(x, y);
39                             x--;
40                         }
41                         printEven(x, y);
42                         y++;
43                         while(x <= H){
44                             printEven(x, y);
45                             x++;
46                         }
47                     }else {
48                         int x = H - i/2 + 1, y = 1;
49                         while(y < len){
50                             printEven(x, y);
51                             y++;
52                         }
53                         printEven(x, y);
54                         x--;
55                         while(y >= 1){
56                             printEven(x, y);
57                             y--;
58                         }
59                     }    
60                 }else{
61                     int len = i/2;
62                     if(i%4 == 0){
63                         int x = H - i/2 + 1, y = 1;
64                         while(y < len){
65                             printEven(x, y);
66                             y++;
67                         }
68                         printEven(x, y);
69                         x--;
70                         while(y >= 1){
71                             printEven(x, y);
72                             y--;
73                         }
74                     }else{
75                         int x = H, y = i/2;
76                         while(x > H - len + 1){
77                             printEven(x, y);
78                             x--;
79                         }
80                         printEven(x, y);
81                         y++;
82                         while(x <= H){
83                             printEven(x, y);
84                             x++;
85                         }
86                     }
87                 }    
88             }
89         printf("\n");    
90         }
91     }
92     return 0;
93 }
目录
相关文章
|
消息中间件 存储 分布式计算
Kafka 3.x的解压安装 - Linux
Kafka 3.x的解压安装 - Linux
998 0
Kafka 3.x的解压安装 - Linux
|
SQL 算法 数据库
【hive】在hive中实现WordCount算法
在hive中实现WordCount算法
308 0
【hive】在hive中实现WordCount算法
|
SQL 存储 分布式计算
Hive安装超详细教程
带领大家进行Hive的安装
3930 0
|
机器学习/深度学习 算法 测试技术
【Python 百练成钢】快速幂合集
【Python 百练成钢】快速幂合集
|
2天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
13天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1286 5
|
12天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1318 87