• PHP算法之Z 字形变换


    将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。

    比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:

    L C I R
    E T O E S I I G
    E D H N
    之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。

    请你实现这个将字符串进行指定行数变换的函数:

    string convert(string s, int numRows);
    示例 1:

    输入: s = "LEETCODEISHIRING", numRows = 3
    输出: "LCIRETOESIIGEDHN"
    示例 2:

    输入: s = "LEETCODEISHIRING", numRows = 4
    输出: "LDREOEIIECIHNTSG"
    解释:

    L D R
    E O E I I
    E C I H N
    T S G

    来源:力扣(LeetCode)

    答案献上

    class Solution {

        /**
         * @param String $s
         * @param Integer $numRows
         * @return String
         */
        function convert($s, $numRows) {
            $len = strlen($s);
            if($len <= $numRows || $numRows <= 1){
                return $s;
            }

            $str = [];
            $line = 1;
            $add = true;

            for($i = 0;$i < $len;$i ++ ){

                $str[$line][]= $s[$i]; 
                
                if($line == 1){
                    $add = true;
                }elseif($line == $numRows){
                    $add = false;
                }

                if($add){
                    ++$line;
                }else{
                    --$line;
                }
            }
            $res = '';
            for($m = 0;$m < $numRows;$m++){
                $res.=implode('',$str[$m+1]);
            }
            
            return $res;    
        }
    }
  • 相关阅读:
    GridView编辑删除取消完整代码
    添加删除组件里没有IIS
    关于网站开发中存在的问题
    网络公司网站源码介绍Version1.0
    IIS 状态代码
    收藏常用的快捷方式
    连接池已经满的解决方案
    Do you choose a experienced employee with highsalary or a inexperienced employee with lowsalary?
    Registered Permanent residence/attitude for sports
    数据缓存依赖
  • 原文地址:https://www.cnblogs.com/corvus/p/11965152.html
Copyright © 2020-2023  润新知