• 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
    示例2的下标对应关系
    //0 6   12
    //1 5 7 11 13
    //2 4 8 10 14
    //3   9    15
    

    思路

    分为三种情况: 1.最初直接由上往下赋值 2.(numsRow-2)~0行 3.1~(numsRow-1)行
    class Solution {
        public String convert(String s, int numRows) {
    
            int sLen = s.length();
            if(numRows >= sLen || numRows == 1){
                return s;
            }
            String []strings = new String[numRows];
            for (int i = 0; i <numRows ; i++) {
    
                strings[i] = s.charAt(i) + "";
            }
            int index1 = 1,index2 = numRows - 2;
            for (int i = numRows; i < sLen ; i++) {
                String str = s.charAt(i)+"";
    
                if(((i-numRows) / (numRows - 1)) % 2 == 1){
                        strings[index1] += str;
                        index1++;
                        if(index1 == numRows){
                            index1 = 1;
                        }
                }else{
                        strings[index2] += str;
                        if(index2 == 0){
                            index2 = numRows-1;
                        }
                        index2--;
    
                }
    
            }
            String res = "";
            for (int i = 0; i <numRows ; i++) {
                res += strings[i];
            }
    
         return res;
        }
    }
    
    
    不一样的烟火
  • 相关阅读:
    微信小程序 'errcode' => 47003,'errmsg' => 'argument invalid! hint
    微信分账
    Acwing-----1016. 最大上升子序列和
    Acwing-----1012. 友好城市
    Acwing-----482. 合唱队形
    Acwing-----1014. 登山
    Acwing-----1017. 怪盗基德的滑翔翼
    Acwing-----275. 传纸条
    Acwing-----1027. 方格取数
    Acwing-----1018. 最低通行费
  • 原文地址:https://www.cnblogs.com/cstdio1/p/13081603.html
Copyright © 2020-2023  润新知