侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法分析

php  /  管理员 发布于 7年前   229

本文实例讲述了PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法。分享给大家供大家参考,具体如下:

回环矩阵指的是一个从一开始,不断按照上、右、下、左顺序依次增大的矩阵序列,例:

1 2 38 9 47 6 5

现在要求:

输入: m、n,分别代表行数和列数
输出: m * n 的回环矩阵

例:

输入:

7 8

输出:

1 2 3 4 5 6 7 826 27 28 29 30 31 32 925 44 45 46 47 48 33 1024 43 54 57 56 49 34 1123 42 53 52 51 50 35 1222 41 40 39 38 37 36 1321 20 19 18 17 16 15 14

接下来我们用 PHP 来实现,这里我们将其封装成函数调用

第一种思路

直接按照上、右、下、左的顺序进行遍历,计算好遍历层数就OK了

function snake($row = 5, $col = 5){  // 结果集  $res = array();  // 初始值  $start = 1;  // 当前遍历层数  $flag = intval(($row + 1) / 2);  for ($i = 1; $i <= $flag; $i++) {    $startX = $i - 1;    $startY = $i - 1;    $width = $col - $i + 1;    $height = $row - $i + 1;    // 上    for ($u = $startY; $u < $width; $u++) {      $res[$startX][$u] = $start;      $start += 1;    }    // 右    for ($r = $startX + 1; $r < $height; $r++) {      $res[$r][$u-1] = $start;      $start += 1;    }    // 下    for ($d = $u - 1 - 1; $d >= $startY; $d--) {      $res[$r-1][$d] = $start;      $start += 1;    }    // 左    for ($l = $r - 1 - 1; $l >= $startX + 1; $l--) {      $res[$l][$d+1] = $start;      $start += 1;    }  }  // 输出  for ($i = 0; $i < $row; $i++) {    for ($j = 0; $j < $col; $j++) {      echo $res[$i][$j] . " ";    }    echo "
"; }}snake(7, 8);

第二种思路

这种思路与第一种思路类似,不过是通过一个 while 全部遍历,然后通过一个标志位 up right down left 来判断与修改当前方向,通过 while 内的 if 来对标志位进行判断,这种就不贴代码了

第三种思路

使用一个迭代器来控制方向,然后进行 m * n 次循环,通过判断宽高和 isset 来确定是否转弯,思路很棒,代码量大大减少,表示没有想到这种方式。。

/* * * @param $w : 宽 * @param $h : 高 * @param $s : 起始数字 * @param $x, $y : 起始位置坐标 只能从四顶点开始 * @param $r :方向 默认顺时间 false为逆时针 * */function print_matrix($w, $h, $s = 1, $l = 1, $x = 0, $y = 0, $r = true) {  // 表示四个方向  $R = array(array(1, 0), array(0, 1), array(-1, 0), array(0, -1));  !$r && $R = array_reverse($R);  // 创建一个无限迭代器  $iterator = new InfiniteIterator(new ArrayIterator($R));  $iterator->rewind();  list($_x, $_y) = $iterator->current();  $result = [];  $result[$x][$y] = $s;  for ($i = $s+1; $i < ($s + $w * $h); $i++) {    $new_x = $x + $_x;    $new_y = $y + $_y;    if (0 <= $new_x && 0 <= $new_y && $new_x < $w && $new_y < $h && !isset($result[$new_x][$new_y])) {      $result[$new_x][$new_y] = $i;      $x = $new_x;      $y = $new_y;    } else {      $iterator->next();      list($_x, $_y) = $iterator->current();      $i--;    }  }  // 打印  for ($i = 0; $i < $h; $i++) {    for ($j = 0; $j < $w; $j++) {      echo $result[$j][$i], "\t";    }    echo "
"; }}

PS:这里再为大家推荐几款在线计算工具供大家参考使用:

在线一元函数(方程)求解计算工具:
http://tools..net.cn/jisuanqi/equ_jisuanqi

科学计算器在线使用_高级计算器在线计算:
http://tools..net.cn/jisuanqi/jsqkexue

在线计算器_标准计算器:
http://tools..net.cn/jisuanqi/jsq

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数学运算技巧总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《php正则表达式用法总结》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。

您可能感兴趣的文章:

  • PHP简单实现二维数组的矩阵转置操作示例
  • PHP实现图的邻接矩阵表示及几种简单遍历算法分析
  • PHP使用数组实现矩阵数学运算的方法示例
  • PHP 数组和字符串互相转换实现方法
  • PHP中数组合并的两种方法及区别介绍
  • PHP遍历数组的方法汇总
  • PHP遍历数组的几种方法
  • php数组函数序列之array_keys() - 获取数组键名
  • php获取数组中重复数据的两种方法
  • PHP实现顺时针打印矩阵(螺旋矩阵)的方法示例


  • 上一条:
    PHP使用数组实现矩阵数学运算的方法示例
    下一条:
    PHP实现的简单AES加密解密算法实例
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客