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;
}
相关推荐
清风明月一壶酒几秒前
OpenClaw自动处理Word文档全流程
开发语言·c#·word
其实防守也摸鱼6 分钟前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
木喃的井盖8 分钟前
无锁队列细节
c++·工程
王老师青少年编程27 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串基础】:输出亲朋字符串
c++·字符串·csp·高频考点·信奥赛·专项训练·输出亲朋字符串
MediaTea1 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z1 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue1 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
小郑加油1 小时前
python学习Day12:pandas安装与实际运用
开发语言·python·学习
AC赳赳老秦1 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
风筝在晴天搁浅2 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法