zoukankan      html  css  js  c++  java
  • 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;
        }
    }
    
    
    不一样的烟火
  • 相关阅读:
    自定义动画(仿Win10加载动画)
    jquery 仿windows10菜单效果下载
    mac os+selenium2+Firefox驱动+python3
    mac os+selenium2+chrome驱动+python3
    mac 安装scrapy
    mac 查看系统位数
    ubuntu安装 mysqldb
    ubuntu安装常用软件
    scp 时出现permission denied
    ubuntu 安装git
  • 原文地址:https://www.cnblogs.com/cstdio1/p/13081603.html
Copyright © 2011-2022 走看看