【python刷题】蛇形方阵

题目描述

给出一个不大于 99 的正整数n,输出n*n的蛇形方阵。从左上角填上1开始,顺时针方向依次填入数字,如同样例所示。注意每个数字有都会占用3个字符,前面使用空格补齐。

输入

输入一个正整数n,含义如题所述

输出

输出符合题目要求的蛇形矩阵

样例

输入 4

输出如下

|--------------------------------------------------------|
| 1 2 3 4 12 13 14 5 11 16 15 6 10 9 8 7 |

算法思路

用二维数组来存放整个矩阵,创建变量num记录当前位置应填入的数字,num超过n^2的时候说明已全部填入,则结束循环。变量top,bottom,left,right来限制每一次遍历的边界范围。变量fx用来记录方向,从而实现层层循环的同时能不断改变遍历的方向。输出时使用f字符串格式化输出从而统一格式。

题解

python 复制代码
n=int(input())
arr=[[0 for _ in range(n)] for _ in range(n)]
fx=0
num=1
left,right,top,bottom=0,n,0,n
while(num<=n**2):
    if(fx==0):
        for i in range(left,right):
            arr[top][i]=num
            num+=1
    fx=1
    top+=1
    if(fx==1):
        for i in range(top,bottom):
            arr[i][right-1]=num
            num+=1
    fx=2
    right-=1
    if(fx==2):
        for i in range(right-1,left-1,-1):
            arr[bottom-1][i]=num
            num+=1
    fx=3
    bottom-=1
    if(fx==3):
        for i in range(bottom-1,top-1,-1):
            arr[i][left]=num
            num+=1
    fx=0
    left+=1
for i in range(n):
    for j in range(n):
        print(f"{arr[i][j]:3}",end="")
    print("\n",end="")
相关推荐
Codeking__4 小时前
Redis的value类型及编码方式介绍——hash
redis·算法·哈希算法
u0104058364 小时前
企业微信通讯录同步服务的增量更新与冲突解决算法
算法·企业微信
码农水水4 小时前
阿里Java面试被问:RocketMQ的消息轨迹追踪实现
java·开发语言·windows·算法·面试·rocketmq·java-rocketmq
智驱力人工智能4 小时前
矿场轨道异物AI监测系统 构建矿山运输安全的智能感知防线 轨道异物检测 基于YOLO的轨道异物识别算法 地铁隧道轨道异物实时预警技术
人工智能·opencv·算法·安全·yolo·边缘计算
橘颂TA4 小时前
【剑斩OFFER】算法的暴力美学——leetcode 429 题:N 叉树的层序遍历
算法
"YOUDIG"4 小时前
信稿笺纸设计工具:传统排版美学与数字化设计的高效融合
科技·考研·算法·面试·职场和发展·高考
程序员-King.4 小时前
day126—二分查找—寻找旋转排序数组中的最小值(LeetCode-153)
算法·leetcode·二分查找
菜鸟233号4 小时前
力扣494 目标和 java实现
java·数据结构·算法·leetcode
有一个好名字4 小时前
力扣-字符串解码
java·算法·leetcode
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章9-均值滤波
人工智能·opencv·算法·计算机视觉·均值算法