笔试在线编程题

平时不怎么刷LC,笔试的时候在规定时间内不能想出来,为此,记录一下这次的面试题目。(告诫一下自己,多刷LC)

顺序螺旋矩阵

class Solution():
    def rotationmatrix(self,matrix:list[list[int]])->list[int]: #类型声明,方便检查
        if not matrix:
            return 0
        left,right=0,len(matrix[0])-1
        top,down=0,len(matrix)-1
        result=[]
        while(True):
            for i in range(left,right+1):
                print(matrix[top][i])
                result.append(matrix[top][i])
            top=top+1
            if top>down:break
            for i in range(top,down+1):
                print(matrix[i][right])
                result.append(matrix[i][right])
            right=right-1
            if right< left:break
            for i in range(right,left-1,-1):
                print(matrix[down][i])
                result.append(matrix[down][i])
            down=down-1
            if down<top:break
            for i in range(down,top-1,-1):
                print(matrix[i][left])
                result.append(matrix[i][left])
            left=left+1
            if left>right:break
        return result
    
a = input().split(' ')
m,n=int(a[0]),int(a[1])#矩阵的行和列
length=len(a)-2 #数组长度
k=2
original_matrix=[]#存储数组
for i in range(m):
    b=[]
    for j in range(n):
        b.append(int(a[k]))
        k=k+1
    original_matrix.append(b)
#print(original_matrix)
solution=Solution()
res=solution.rotationmatrix(original_matrix)
print(res)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七月花nancy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值