zoukankan      html  css  js  c++  java
  • 字符串操作 —— 6_Z字形变换

    1. 6_Z字形变换
    /*
    输入: s = "LEETCODEISHIRING", numRows = 4
    输出: "LDREOEIIECIHNTSG"
    解释:
    L     D     R
    E   O E   I I
    E C   I H   N
    T     S     G
    */
    class Solution {
        public String convert(String s, int numRows) {
            if(s == null || s.length() == 0 || numRows <= 1) return s;
            StringBuilder[] array = new StringBuilder[numRows];
            for(int i=0; i < numRows; i++) array[i] = new StringBuilder();
            int dir = 1;
            int index = 0;
            for(char c : s.toCharArray()){
                array[index].append(c);
                index += dir;
                if(index == 0 || index == numRows-1) dir = -dir;
            }
            StringBuilder ret = new StringBuilder();
            for(int i=0; i < numRows; i++) ret.append(array[i]);
            return ret.toString();
        }
    }
    
    class Solution {
        public String convert(String s, int numRows) {
    
            if (numRows == 1) return s;
    
            StringBuilder ret = new StringBuilder();
            int n = s.length();
            int cycleLen = 2 * numRows - 2;
    
            for (int i = 0; i < numRows; i++) {
                for (int j = 0; j + i < n; j += cycleLen) {
                    ret.append(s.charAt(j + i));
                    if (i != 0 && i != numRows - 1 && j + cycleLen - i < n)
                        ret.append(s.charAt(j + cycleLen - i));
                }
            }
            return ret.toString();
        }
    }
    
  • 相关阅读:
    032 代码复用与函数递归
    031 实例7-七段数码管绘制
    030 函数的定义与使用
    029 函数和代码复用
    2.4 Buffer
    2.3 字符串链接
    2.2 去除字符串特别字符
    2.1 字符串查询
    存储数据_文件读写
    template模板
  • 原文地址:https://www.cnblogs.com/s841844054/p/13736404.html
Copyright © 2011-2022 走看看