P5731 蛇形方阵题解

题目传送门

#include <bits/stdc++.h>

using namespace std;
const int N = 10;
int a[N][N];
//右下左上,顺序不能反,因为本题的蛇形是顺时针方向
int dx[] = {0, 1, 0, -1};
int dy[] = {1, 0, -1, 0};
int n;

int main() {
    cin >> n;
    //出发点
    int x = 0, y = 0;
    a[0][0] = 1;

    int dir = 0; //方向
    for (int i = 2; i <= n * n; i++) {
        //下一个位置,优先尝试当前方向的下一个位置,也可能不行
        int nx = x + dx[dir], ny = y + dy[dir];
        //下一个位置不能出界,不能走过
        if (nx == n || nx < 0 || ny == n || ny < 0 || a[nx][ny])
            dir = (dir + 1) % 4;
        //终于找对了前进方向,走之~
        x += dx[dir], y += dy[dir], a[x][y] = i;
    }
    //输出结果
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++)
            printf("%3d", a[i][j]);
        printf("\n");
    }
    return 0;
}
posted @   糖豆爸爸  阅读(344)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2018-07-21 在Centos中安装aria2c
2016-07-21 PHP、JAVA、C#、Object-C 通用的DES加密
Live2D
点击右上角即可分享
微信分享提示