“之” 字形打印矩阵-python3

本文介绍如何使用Python3实现'之'字形打印矩阵。通过定义一个布尔变量来控制打印方向,实现了上下来回交替的打印效果。

该问题要先打印指定的一条斜线。

由于之字形打印是上下来回交替着打印,所以要定义一个bool变量来指示打印的方向。

代码如下:

#coding=utf-8
'''
“之” 字形打印矩阵
【 题目】 给定一个矩阵matrix, 按照“之” 字形的方式打印这
个矩阵, 例如: 1 2 3 4
               5 6 7 8
              9 10 11 12
“之” 字形打印的结果为: 1, 2, 5, 9, 6, 3, 4, 7, 10, 11,
8, 12
【 要求】 额外空间复杂度为O(1)。
'''
import numpy as np
def printMatrixZigZag(matrix):
    aR,aC=0,0
    bR,bC=0,0
    endR=matrix.shape[0]-1
    endC=matrix.shape[1]-1
    fromUp=False
    while aR!=endR+1:
        printLevel(matrix,aR,aC,bR,bC,fromUp)
        # 下面四句改变顺序会报错(if判断条件的原因)
        aR=aR+1 if aC==endC else aR
        aC=aC if aC==endC else aC+1
        bC = bC + 1 if bR == endR else bC
        bR=bR if bR==endR else bR+1

        fromUp=not fromUp
def printLevel(m,aR,aC,bR,bC,fromUp):
    if fromUp:
        while aR!=bR+1: #边界
            p
Python中,有两种常见的Z字形打印场景,分别是Z字形打印矩阵和Z字形变换字符串,以下为对应的实现方法: ### Z字形打印矩阵 代码通过 `ZigZagPrintMatrix` 函数实现矩阵的Z字形打印,`print_level` 函数用于打印矩阵中特定对角线的元素。 ```python def ZigZagPrintMatrix(arr): tc = 0 tr = 0 dr = 0 dc = 0 end_r = len(arr) - 1 end_c = len(arr[0]) - 1 reverse_flag = False while tr != end_r + 1: print_level(arr, tr, tc, dr, dc, reverse_flag) tr = tr + 1 if tc == end_c else tr tc = tc if tc == end_c else tc + 1 dc = dc + 1 if dr == end_r else dc dr = dr if dr == end_r else dr + 1 reverse_flag = not reverse_flag def print_level(arr, tr, tc, dr, dc, reverse_flag): if reverse_flag == False: while dr != tr - 1: print(arr[dr][dc], end=' ') dr -= 1 dc += 1 else: while tr != dr + 1: print(arr[tr][tc], end=' ') tr += 1 tc -= 1 if __name__ == '__main__': li = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]] ZigZagPrintMatrix(li) ``` ### Z字形变换字符串 代码使用 `Solution` 类的 `convert` 方法,将输入字符串按指定行数进行Z字形排列后,逐行读取生成新字符串。 ```python class Solution: def convert(self, s: str, numRows: int) -> str: k, res = {}, '' for x in range(numRows): k[x] = '' for x in range(len(s)): r = 0 if numRows > 1: r = x % (2 * numRows - 2) if r > numRows - 1: k[2 * numRows - 2 - r] += s[x] else: k[r] += s[x] for x in k: res += k[x] return res ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值