当前位置: 首页 > news >正文

网站建设的技术保证怎么写兰州网站开发公司

网站建设的技术保证怎么写,兰州网站开发公司,国内高校网站建设的调查,wordpress copyright1、这种题目是对代码熟练度考察,模拟顺时针建立或访问矩阵,需要注意矩阵是否为方阵 2、具体思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当小的行列值为奇数,最后一圈为一行或一列或一个数字的不…

1、这种题目是对代码熟练度考察,模拟顺时针建立或访问矩阵,需要注意矩阵是否为方阵
2、具体思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈
3、细节:把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便完整圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新

59. 螺旋矩阵 II

from typing import List
'''
59. 螺旋矩阵 II
题目描述:给你一个正整数 n ,生成一个包含 1 到 n^2 的所有元素,且元素按顺时针顺序螺旋排列的 n i n 正方形矩阵 matrii 。
示例 1:输入:n = 3输出:[[1,2,3],[8,9,4],[7,6,5]]
题眼:代码熟练度考察,模拟顺时针建立矩阵,注意是方阵,复杂度降低了些
思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当n为奇数,恰好留了一个中心元素待更新
注意把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新
'''class Solution:def generatedMatrii(self, n: int) -> List[List[int]]:result = [[0] * n for _ in range(n)]# 以圈数为循环条件,每一圈都坚持左闭右开的区间规则count = 1up, down, left, right = 0, n - 1, 0, n - 1  # 起始圈的上下左右边界i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标for _ in range(n // 2):  # 总圈数为 n // 2while i == up and j < right:  # 上result[i][j] = countj += 1count += 1while i < down and j == right:  # 右result[i][j] = counti += 1count += 1while i == down and j > left:  # 下result[i][j] = countj -= 1count += 1while i > up and j == left:  # 左result[i][j] = counti -= 1count += 1# 更新圈的上下左右边界up, down, left, right = up + 1, down - 1, left + 1, right - 1i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标# 当n为奇数,恰好留了一个中心元素待更新if n % 2 == 1:result[up][left] = countreturn resultif __name__ == "__main__":obj = Solution()while True:try:n = int(input().strip().split('=')[1])print(obj.generatedMatrii(n))except EOFError:break

54. 螺旋矩阵

from typing import List
'''
54. 螺旋矩阵
题目描述:给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
示例 1:输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]输出:[1,2,3,6,9,8,7,4,5]
题眼:代码熟练度考察,模拟顺时针返回矩阵元素,注意不是方阵,有点复杂度
思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈
注意把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新
'''class Solution:def spiralOrder(self, matrix: List[List[int]]) -> List[int]:m, n = len(matrix), len(matrix[0])result = []# 以圈数为循环条件,每一圈都坚持左闭右开的区间规则up, down, left, right = 0, m - 1, 0, n - 1  # 起始圈的上下左右边界i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标for _ in range(min(m, n) // 2):  # 总圈数为 小的行列值除以2while i == up and j < right:  # 上result.append(matrix[i][j])j += 1while i < down and j == right:  # 右result.append(matrix[i][j])i += 1while i == down and j > left:  # 下result.append(matrix[i][j])j -= 1while i > up and j == left:  # 左result.append(matrix[i][j])i -= 1# 更新圈的上下左右边界up, down, left, right = up + 1, down - 1, left + 1, right - 1  # 起始圈的上下左右边界i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标# 当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈if min(m, n) % 2 == 1:if up == down and left == right:  # 一个数字result.append(matrix[up][left])elif up != down and left == right:  # 一列,对应的列索引为leftfor k in range(up, down + 1):result.append(matrix[k][left])elif up == down and left != right:  # 一行,对应的行索引为upfor k in range(left, right + 1):result.append(matrix[up][k])return resultif __name__ == "__main__":obj = Solution()while True:try:in_line = input().strip().split('=')matrix = []for row in in_line[1].strip()[1: -1].split(']')[: -1]:matrix.append([int(n) for n in row.split('[')[1].split(',')])print(obj.spiralOrder(matrix))except EOFError:break
http://www.yayakq.cn/news/522817/

相关文章:

  • 偃师 做网站做二手手机的网站有哪些
  • 织梦网站建设交流群郑州百度快照优化
  • 云南网站建设百度c 做网站如何调用dll
  • 网站建设的市场有多大如何做网站图片
  • 千助做网站怎么样app平台开发定制软件
  • 封开网站建设dede本地搭建网站
  • 吉林省建设厅网站查询做个企业网站要多少钱
  • wordpress站点预览专门做cg视频网站
  • 网站建设哪家服务周到网站不支持ie8
  • 自媒体横行还有做网站做网站云服务器选择多大带宽
  • wordpress网站前端十大免费无代码开发软件
  • 好的建站软件淘宝网站的内容建设
  • 金麦建站官网黑客是如何攻击网站的
  • 合肥做网站工作室dede静态网站
  • 上海外贸soho网站建设织梦网站如何做二级导航栏
  • 做的好的区块链网站中国建设报社门户网站
  • 建设信用卡网站昆明网站推广优化公司
  • 山西网站制作应用网页图片下载工具
  • 建站公司用的服务器贵州网站建设价格
  • 网站建设河南seo网站策划书
  • 114啦网址导航建站系统wordpress国外空间
  • 海安网站建设阳江网梁国燊事件
  • 做百度推广是不是得有个网站先邵阳seo优化
  • 衡水市网站制作室内装修设计自学教材
  • 宣传册设计及网站建设wordpress 企业
  • 技术支持 张家港网站建设制作网站源码
  • 定制化网站开发多少钱空壳网站查询
  • 海南建设大厅网站大学生网页设计作业教程
  • 外贸网站如何引流小红书app是哪家公司开发的
  • 建设英文网站要求网站降权怎么做