C++蛇形方阵

这段C++代码实现了一个螺旋填充n×n矩阵的算法。程序首先读取整数n,然后创建一个n×n的零矩阵。通过定义四个方向(右、下、左、上),从(0,0)位置开始按顺时针螺旋顺序填充数字1到n²。当遇到边界或已填充位置时,算法会顺时针旋转90度寻找下一个可填充位置。最后输出完整的螺旋矩阵。例如输入4时,输出如题目所示的特定数字排列。该算法通过方向向量和边界检查实现了矩阵的螺旋填充功能。

输入

4

输出

1 2 3 4

12 13 14 5

11 16 15 6

10 9 8 7

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;
    cin>>n;
    vector<vector<int>> matrix(n, vector<int>(n, 0));
    int dx[4]={0,1,0,-1};
    int dy[4]={1,0,-1,0};
    int x=0,y=0;
    int d=0;
    int num=1;
    matrix[x][y]=num++;
    while(num<=n*n){
        int nx=x+dx[d];
        int ny=y+dy[d];
        if(nx>=0&&nx<n&&ny>=0&&ny<n&&matrix[nx][ny]==0){
            x=nx;
            y=ny;
        }else{
            bool found=false;
            for (int i=1;i<=3;i++){
                int nd=(d+i)%4;
                int nx=x+dx[nd];
                int ny=y+dy[nd];
                if(nx>=0&&nx<n&&ny>=0&&ny<n&&matrix[nx][ny]==0) {
                    d=nd;
                    x=nx;
                    y=ny;
                    found=true;
                    break;
                }
            }
        }
        matrix[x][y]=num++;
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            cout<<matrix[i][j];
            if(j<n-1)cout<<" ";
        }
        cout<<endl;
    }
    return 0;
}
相关推荐
驭渊的小故事2 分钟前
简单模板笔记
数据结构·笔记·算法
YuTaoShao17 分钟前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
BD_Marathon22 分钟前
设计模式——依赖倒转原则
java·开发语言·设计模式
VT.馒头23 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa33 分钟前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior33 分钟前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
devmoon41 分钟前
在 Polkadot Runtime 中添加多个 Pallet 实例实战指南
java·开发语言·数据库·web3·区块链·波卡
Evand J44 分钟前
TDOA(到达时间差)的GDOP和CRLB计算的MATLAB例程,论文复现,附参考文献。GDOP:几何精度因子&CRLB:克拉美罗下界
开发语言·matlab·tdoa·crlb·gdop
野犬寒鸦44 分钟前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
云姜.1 小时前
java抽象类和接口
java·开发语言