码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode] Z字型变换

时间:2018-10-28 11:55:37      阅读:111      评论:0      收藏:0      [点我收藏+]

标签:实现   convert   指定   最优   pre   leetcode   分享图片   res   hrp   

题目内容:

将字符串 "PAYPALISHIRING" 以Z字形排列成给定的行数:

P   A   H   N
A P L S I I G
Y   I   R
之后从左往右,逐行读取字符:"PAHNAPLSIIGYIR"

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

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

输入: s = "PAYPALISHIRING", numRows = 3
输出: "PAHNAPLSIIGYIR"
示例 2:

输入: s = "PAYPALISHIRING", numRows = 4
输出: "PINALSIGYAHRPI"

  

思路:

找规律的题目,字符串各字母内容不管,找下标的规律,拿上面的第二个样例为例子,下标排列是这样子的

 /*
        * 0     6     12
        * 1   5 7  11 13
        * 2  4  8 10  14
        * 3     9     
        * */

  

可以看出,除去斜边的,每一行都是一个等差数列,例如0,6,12

而斜边的是竖排中的数加上某一个固定值,例如第二行就是1+4=5,7+4=11

然后综合可以总结出规律,等差数列的差是numRows+numRows-2,即2*numRows-2,其实就是同一行相邻数字中隔的数字

然后每一行中间要加的固定值,是前面等差数列的差依次-2,因为每向下一行两个数间隔就少两个数,例如第二行固定值4,第三行固定值就是4-2=2

之后就是用代码实现了,相信也不难写了

if(numRows>s.length()||numRows==1)
            return s;
        int length = s.length();
        int count = numRows*2-2;
        int next = 0;
        String result = "";
        for(int i = 0;i < numRows;i++){
            for(int j = i;j < length;){
                result = result + s.charAt(j);
                next = j + count - 2 * i;
                if(i!=0&&i!=numRows-1&&next<length){
                    //第一行和最后一行竖排中的数加上固定值和这个数字在等差数列的下一个值相等
                    //所以这两行不管它
                    result = result + s.charAt(next);
                }
                j = j + count;
            }
        }
        return result;

  

这个还不是最优解,到时候看看还能不能优化

技术分享图片

 

[LeetCode] Z字型变换

标签:实现   convert   指定   最优   pre   leetcode   分享图片   res   hrp   

原文地址:https://www.cnblogs.com/Yintianhao/p/9864952.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!