题目:s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"PAHNAPLSIIGYIR"。
请你实现这个将字符串进行指定行数变换的函数:
class Solution{public String convert(String s,int numRows){int n=s.length(),r=numRows;if(r==1||r>=n){return s; } int t=r*2-2;int c=(n+t-1)/t*(r-1);char[][]mat=new char[r][c];for(int i=0,x=0,y=0;i<n;++i){mat[x][y] = s.charAt(i);if (i % t < r - 1) {++x; // 向下移动} else {--x;++y; // 向右上移动}}StringBuffer ans = new StringBuffer();for (char[] row : mat) {for (char ch : row) {if (ch != 0) {ans.append(ch);}}}return ans.toString();}
}