Easy-题目61:6. ZigZag Conversion
2016-05-30 22:39
281 查看
题目原文:
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)
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)
成绩:
33ms,beats 25.35%,众数8ms,15.13%
cmershen的碎碎念:
本题成绩较差,可能是存在更简洁的规律,或者从stl的函数调用上试图优化。毕竟数量级为O(n)已经没法再缩小了。
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)已经没法再缩小了。
相关文章推荐
- android studio 导入第三方开源框架/项目,第三方Jar包
- 《图解TCP/IP》读书笔记(3)
- 2.4.位运算实战演练1
- XHTML
- 最新方法制作自己的cocoapods开源框架的详细步骤
- 友盟分享中分享到微信只有文字信息没有要跳转的链接
- java中读取输入的方式
- 设计模式学习笔记之综述
- String、StringBuffer和StringBuilder的区别
- 思考--测试应该从代码中读懂什么
- CSS3实现可伸缩输入框
- 设计模式23篇:迭代器模式
- MySQL 加锁处理分析
- LLBL Gen Pro 5.0
- java-Netty学习(2)
- WIN7X64 安装Wampserver 2.5 启动提示“丢失MSVCR110.dll”
- iOS中NSAttributedString用法
- [学习记录] 5/30
- 作业
- [从产品角度学EXCEL 03]-单元格的秘密