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

小而巧的数字压缩算法:zigzag

thrift里面简单·美的几十行代码~
  • zgwangbo
  • zgwangbo
  • 2016年06月07日 07:24
  • 11568

第十七周(ZigZag Conversion)

第十七周(ZigZag Conversion )目录: 本周完成题目 主要过程思路 相关代码 一、本周完成题目 本周共完成2道题目,1道Medium,1道Easy。 具体完成题目及难度如下表:...
  • qq_24486635
  • qq_24486635
  • 2017年06月05日 17:34
  • 46

【python】【leetcode】【算法题目6—ZigZag Conversion】

【python】【leetcode】【算法题目6—ZigZag Conversion】 题目原文: The string "PAYPALISHIRING" is written in a zigzag...
  • u014615155
  • u014615155
  • 2016年11月26日 15:44
  • 383

动态规划04—最长的zigzag序列

topcode链接: https://community.topcoder.com/statc=problem_statement&pm=1259&rd=4493 problem:A sequen...
  • kesonyk
  • kesonyk
  • 2016年05月10日 22:10
  • 1276

锯齿转变(ZigZag Conversion)

The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (you...
  • sinat_36246371
  • sinat_36246371
  • 2016年10月12日 22:44
  • 213

ZigZag Conversion(“Z”形转换)

The string “PAYPALISHIRING” is written in a zigzag pattern on a given number of rows like this: (字符...
  • ajiangfan
  • ajiangfan
  • 2016年12月12日 16:53
  • 159

每日博客之六:ZigZag Conversion

题目要求是Z字形输出,先竖排,到了nRows之后,之后的字符放在nRows-1行,单独成一列,依次递推,到底一行后,之后的元素放在前一个元素的下方,以此类推即可。...
  • yapian8
  • yapian8
  • 2014年05月04日 22:08
  • 631

【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
  • 142

TopCoder:ZigZag(动态规划--最长非降子序列)

看动态规划的题 在topcoder里看的这道题就来练练手 Problem Statement  A sequence of numbers is called a zig-zag sequence ...
  • yf224
  • yf224
  • 2017年05月09日 17:41
  • 213

第七周算法分析与设计:ZigZag Conversion

算法描述: The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like th...
  • qq_20353557
  • qq_20353557
  • 2017年04月10日 10:30
  • 51
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Easy-题目61:6. ZigZag Conversion
举报原因:
原因补充:

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