ZigZag Conversion

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" .

Subscribe to see which companies asked this question

首先我们从简单的例子找一下规律,我们不看真的字母排序而是指看字母所在位置的排序。假设我们有n个字母,那么我们就有1到n这n个位置。


一: 2排的时候,1到n的排序
1 3 5 7 9   。。。
2 4 6 8 10 。。。


二: 3排的时候,1到n的排序
1    5    9   。。。
2 4 6 8 10 。。。
3    7    11 。。。

三: 4排的时候,1到n的排序
1      7          13 。。。 
2   6 8      12 14 。。。
3 5   9   11    15 。。。
4      10         16 。。。

这到规律没有?如果没有找到, 你可以继续写5排的情况。很快你就可以找到规律。这是一个解决问题问题的方法。当我们遇到难缠的问题的时候,我们先考虑简单的情形,看看能不能找到规律。这个题目,我们通过写出来这些特殊情况,我们发现如下规律,这里我们假设我们分成m排:
1 第i排从i开始
2 第i排两个数的间隔是2(i-1),2(m-i)交替


下面的代码通过了LeetCode online judge large

01 string  convert(string  s,  int  nRows)  {
02   string  result;
03  
04   if(nRows  ==  1{
05      return  s;
06   }
07  
08   for( int  0nRows;  i++)  {
09      int  i;
10      bool  flag  true;
11      while(j  s.size())  {
12         result.push_back(s[j]);
13        
14         if(i  ==  0  ||  ==  nRows  1{
15            +=  2  (nRows  1);
16         }
17         else  {
18            if(flag)  {
19               +=  2  (nRows  1  i);
20               flag  false;
21            }
22            else  {
23               +=  2  i;
24               flag  true;
25            }
26         }
27      }
28   }
29   return  result;
30 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值