博客
关于我
螺旋矩阵-ii(数组)
阅读量:366 次
发布时间:2019-03-04

本文共 1877 字,大约阅读时间需要 6 分钟。

题目描述

给定一个整数n,将数字1到n²按螺旋的顺序填入n×n的矩阵中。例如,n=3时,填充顺序为1,2,3,4,5,6,7,8,9,填入矩阵后呈现如下:
[ [1, 2, 3],
[8, 9, 4],
[7, 6, 5] ]

解决方案代码

#include 
using namespace std; vector
> generateMatrix(int n) { vector
> matrix(n, vector
(n)); int left = 0, right = n - 1, up = 0, down = n - 1; int index = 1; while (left <= right && up <= down) { // 填充左边 for (int i = left; i <= right; ++i) { matrix[up][i] = index++; } // 填充右边 for (int i = up + 1; i <= down; ++i) { matrix[i][right] = index++; } // 填充下边(逆向) for (int i = right - 1; i >= left; --i) { matrix[down][i] = index++; } // 填充左边(逆向) for (int i = down - 1; i >= up + 1; --i) { matrix[i][left] = index++; } // 展开到下一层 left++; right--; up++; down--; } return matrix; }

错误分析

在开发螺旋矩阵填充算法时,常见的错误之一是数组维度的错误设置。例如,我曾错误地创建了一个(n+1)×(n+1)的二维数组,这导致填充顺序完全混乱,结果与预期不符。

解决方案

通过仔细分析螺旋填充的逻辑,可以发现每一层都需要从四个方向依次填充:左→右→下→左。每填充完一层,边界就需要向内移动一层,直到无法再向内移动为止。

常见错误

  • 数组维度错误:确保矩阵的大小为n×n,而非(n+1)×(n+1)。
  • 填充顺序错误:必须严格按照螺旋顺序依次填充四个边。
  • 移动边界时逻辑错误:边界的移动必须与填充顺序保持一致,否则会导致重复填充或遗漏某些数字。
  • 最终实现

    通过上述分析,我修正了代码中的错误,确保了螺旋矩阵的正确生成。以下是修正后的代码:

    #include 
    using namespace std; vector
    > generateMatrix(int n) { vector
    > matrix(n, vector
    (n, 0)); int left = 0, right = n - 1, up = 0, down = n - 1; int index = 1; while (left <= right && up <= down) { // 填充左边 for (int i = left; i <= right; ++i) { matrix[up][i] = index++; } // 填充右边 for (int i = up + 1; i <= down; ++i) { matrix[i][right] = index++; } // 填充下边(逆向) for (int i = right - 1; i >= left; --i) { matrix[down][i] = index++; } // 填充左边(逆向) for (int i = down - 1; i >= up + 1; --i) { matrix[i][left] = index++; } // 展开到下一层 left++; right--; up++; down--; } return matrix; }

    这个代码通过严格的边界控制和填充顺序,确保了螺旋矩阵的正确生成。通过不断测试和调试,排除了数组维度和边界移动逻辑上的错误,最终实现了正确的螺旋矩阵填充。

    转载地址:http://eydg.baihongyu.com/

    你可能感兴趣的文章
    Openlayers实战:加载高德地图
    查看>>
    Openlayers实战:测量长度,测量面积
    查看>>
    Openlayers实战:点击某点,overlay显示经纬度坐标
    查看>>
    Openlayers实战:界面控制综合演示
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:绘制带箭头的线
    查看>>
    Openlayers实战:绘制点、线、圆、多边形
    查看>>
    Openlayers实战:绘制矩形,正方形,正六边形
    查看>>
    Openlayers实战:自定义放大缩小,显示zoom等级
    查看>>
    Openlayers实战:自定义版权属性信息
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
    查看>>
    Openlayers实战:非4326,3857的投影
    查看>>
    Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
    查看>>
    Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
    查看>>