Easy-题目61:6. ZigZag Conversion

原创 2016年05月30日 22:39:38

题目原文:
The string “PAYPALISHIRING” is written in a zigzag pattern on a given number of rows like this: (you may want to display this pattern in a fixed font for better legibility)

P   A   H   N
A P L S I I G
Y   I   R

And then read line by line: “PAHNAPLSIIGYIR”
Write the code that will take a string and make this conversion given a number of rows:

string convert(string text, int nRows);
convert(“PAYPALISHIRING”, 3) should return “PAHNAPLSIIGYIR”.
题目大意:
把一个字符串排成n行的锯齿,再按正常顺序(从左到右,从上到下)输出。
题目分析:
首先看一下规律:(例如输入字母a-z,nRows=3),则生成的锯齿如下:

观察每行中字母的下标:(A对应下标0,以此类推)
第一行:0,4,8,12…
第二行:1,3,5,7…
第三行:2,6,10,14…
发现都是等差数列!那么再看一下nRows=4的情况吧!(毕竟这样的规律不是做数学题,不需要用严格的数学归纳法证明,只需大概看出规律即可推广到任意nRows)

观察下标:
第一行:0,6,12,18…
第二行:1,5,7,11,13…
第三行:2,4,8,10…
第四行:3,9,15,21
观察到第二行和第三行不再是等差数列,而是差值分别为2,4交替出现。
由此得出规律:每一行都是两个差值Step1和Step2交替出现,每读完一行Step1递减2,Step2递增2。但有两种特殊情况:一是首末两行差值有一个为0,二是nRows为奇数时最中间一行的Step1=Step2.
结合具体实例来看:
nRows=3时:
第一行Step1=0,Step2=4;
第二行Step1=2,Step2=2;
第三行Step1=4,Step2=0。
nRows=4时:
第一行Step1=0,Step2=6;
第二行Step1=2,Step2=4;
第三行Step1=4,Step2=2;
第四行Step1=6,Step2=0。
据此设计算法,用一个类似于开关的布尔变量记录应该加step1还是加step2,然后逐行读取。
源码:(language:java)

public class Solution {
    public String convert(String s, int numRows) 
    {
        if(numRows==1)
            return s;
        else    {
            String answer="";
            int step1=(numRows-1)*2;
            int step2=0;

            for(int i=0;i<numRows;i++)  {
                String line="";
                int j=i;
                boolean isStep1=true;
                while(j<s.length()) {
                    if(step2==0)    {
                        line+=s.charAt(j);
                        j+=step1;
                    }
                    else if(step1==0) {
                        line+=s.charAt(j);
                        j+=step2;
                    }
                    else    {
                        line+=s.charAt(j);
                        if(isStep1)
                            j+=step1;
                        else
                            j+=step2;
                        isStep1=!isStep1;
                    }
                }
                answer=answer+line;
                step1-=2;
                step2+=2;
            }
            return answer;
        }
    }
}

成绩:
33ms,beats 25.35%,众数8ms,15.13%
cmershen的碎碎念:
本题成绩较差,可能是存在更简洁的规律,或者从stl的函数调用上试图优化。毕竟数量级为O(n)已经没法再缩小了。

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

相关文章推荐

LeetCode题目:6. ZigZag Conversion Add to List

题目原址:点击打开链接 题目描述:The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of row...

【leetcode】第6题 ZigZag Conversion 题目+解析+代码

【题目】 The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this:...
  • buppt
  • buppt
  • 2017-08-09 11:29
  • 61

LEETCODE 6 ZigZag Conversion JAVA

LEETCODE JAVA题解 第六题

leetcode 6. ZigZag Conversion-Zizag转换

原题链接:6. ZigZag Conversion 【思路1】 public String convert(String s, int numRows) { if(numR...

leetcode_6_ZigZag Conversion

思路: 想了好久,思维总是局限在二维数组,找字符串的长度和二维数组的行列数之间的某种联系,想了好久,没有思路。 然后,然后就上网看了一下,有一种思路说是用字符串数组即可,就想到了StringBuil...

LeetCode-6(ZigZag Conversion)

The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (yo...

[leetcode: Python]6. ZigZag Conversion

The string “PAYPALISHIRING” is written in a zigzag pattern on a given number of rows like this: (you...
  • NXHYD
  • NXHYD
  • 2017-05-18 17:33
  • 325

LeetCode之6---ZigZag Conversion

题目:      The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like...

LeetCode OJ-6.ZigZag Conversion

LeetCode OJ-6.ZigZag Conversion题目描述 The string "PAYPALISHIRING" is written in a zigzag pattern on ...

《LeetBook》leetcode题解(6): ZigZag Conversion[E]

006.ZigZag Conversion[E]ZigZag ConversionE 题目 思路1用字符串数组 思路2观察规律题目The string “PAYPALISHIRING” is writ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)