全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

如何实现蛇形遍历二维网格并生成坐标路径

本文介绍如何编写一个函数,对嵌套列表表示的二维网格进行蛇形(之字形)遍历:偶数行从左到右、奇数行从右到左,返回每个访问位置的 (列索引, 行索引) 坐标元组列表。

在网格遍历类问题中,“蛇形路径”(zigzag or serpentine order)是一种常见模式:它要求遍历行为随行号奇偶性动态切换方向。关键在于——方向控制应作用于列索引序列,而非原始数据本身。原代码中的错误正在于此:它对 row(某一行的数据)调用了 reverse_list,但后续仍用 range(len(reverse_row)) 生成列索引,这实际上完全忽略了 reverse_row 的内容,导致奇数行仍按 (0,i), (1,i), ... 顺序添加坐标,与预期的反向遍历(如 (4,i), (3,i), ...)不符。

正确做法是:为每一行生成标准列索引列表 col_indices = list(range(len(row))),再根据行号奇偶性决定是否对其索引序列进行反转。这样既能保持坐标语义清晰((column, row)),又能精准控制移动顺序。

以下是修正后的完整实现:

def reverse_list(input_list):
    return input_list[::-1]

def student_function(field):
    plough_movements = []

    for row_index, row in enumerate(field):
        col_indices = list(range(len(row)))  # 标准列索引 [0, 1, 2, ..., len(row)-1]

        if row_index % 2 == 0:
            # 偶数行(0, 2, 4...):正向遍历 → (0, r), (1, r), (2, r), ...
            plough_movements.extend([(col, row_index) for col in col_indices])
        else:
            # 奇数行(1, 3, 5...):反向遍历 → (len-1, r), (len-2, r), ..., (0, r)
            reversed_cols = reverse_list(col_indices)
            plough_movements.extend([(col, row_index) for col in reversed_cols])

    return plough_movements

验证示例
假设 field = [[0,1,2,3,4], [0,1,2,3,4], [0,1,2,3,4]](3 行 × 5 列),则输出为:
[(0,0),(1,0),(2,0),(3,0),(4,0), (4,1),(3,1),(2,1),(1,1),(0,1), (0,2),(1,2),(2,2),(3,2),(4,2)]
完全符合“偶行左→右、奇行右→左”的蛇形坐标路径。

⚠️ 注意事项

  • 坐标格式为 (column, row)(非 (row, column)),这是由题目示例结果明确规定的(如 (0,0), (1,4) 等均体现列在前、行在后);
  • field 是一个非空嵌套列表,每行长度可不等,但代码已通过 len(row) 动态适配;
  • reverse_list 函数虽可直接用 reversed() 或切片替代,但保留它体现了模块化与复用设计意图;
  • 时间复杂度为 O(N)(N 为总单元格数),空间复杂度为 O(1)(除输出列表外无额外增长空间)。

该实现简洁、可读性强,且严格满足题目对路径方向与坐标格式的双重约束,适用于自动化耕作模拟、矩阵扫描、UI 渲染序等实际场景。


# 切片  # len  # column  # ui  # 自动化  # 遍历  # 行号  # 是一个  # 这是  # 是一种  # 适用于  # 对其  # 又能  # 可直接  # 而非 


相关文章: 济南专业网站制作公司,济南信息工程学校怎么样?  ,柠檬视频怎样兑换vip?  唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?  建站168自助建站系统:快速模板定制与SEO优化指南  北京专业网站制作设计师招聘,北京白云观官方网站?  北京网站制作公司哪家好一点,北京租房网站有哪些?  Android使用GridView实现日历的简单功能  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何用IIS7快速搭建并优化网站站点?  宝塔建站后网页无法访问如何解决?  详解jQuery中基本的动画方法  如何通过FTP空间快速搭建安全高效网站?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  小型网站制作HTML,*游戏网站怎么搭建?  ,sp开头的版面叫什么?  如何在阿里云虚拟服务器快速搭建网站?  焦点电影公司作品,电影焦点结局是什么?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  建站之星收费标准详解:套餐费用及年费价格表一览  佛山企业网站制作公司有哪些,沟通100网上服务官网?  北京企业网站设计制作公司,北京铁路集团官方网站?  广州美橙建站如何快速搭建多端合一网站?  c# 在高并发场景下,委托和接口调用的性能对比  如何通过VPS建站实现广告与增值服务盈利?  建站之星多图banner生成与模板自定义指南  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  如何配置IIS站点权限与局域网访问?  大连网站制作公司哪家好一点,大连买房网站哪个好?  Android滚轮选择时间控件使用详解  专业网站建设制作报价,网页设计制作要考什么证?  如何快速打造个性化非模板自助建站?  建站之星代理商如何保障技术支持与售后服务?  如何通过山东自助建站平台快速注册域名?  北京网站制作的公司有哪些,北京白云观官方网站?  Python如何创建带属性的XML节点  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  家庭建站与云服务器建站,如何选择更优?  详解jQuery停止动画——stop()方法的使用  如何用好域名打造高点击率的自主建站?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何在Windows 2008云服务器安全搭建网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  C#如何使用XPathNavigator高效查询XML  python的本地网站制作,如何创建本地站点?  网站制作免费,什么网站能看正片电影?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  宝塔面板如何快速创建新站点?  存储型VPS适合搭建中小型网站吗? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。