ZigZag Conversion

这个问题困扰了我一个下午!!!

首先我们从简单的例子找一下规律,我们不看真的字母排序而是指看字母所在位置的排序。假设我们有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 }

上面的程序是抄袭别人的   我自己再看了别人的程序的基础之上实现了一个java程序:
public class Solution {
    public String convert(String s, int nRows) {
        
        String ss = "";
        if(nRows==1||s.length()<=nRows) return s;
        
        //假设行数的编号从一开始,那么每一行的数据都是按照间隔数据的2(i-1)和2(m-i)的间隔交替出现的。
        for(int i = 1;i<=nRows;i++){
            int m = i;
            //最初的间隔是m-i;
            int range = 2*(nRows-i);
            while(m<=s.length()){
                ss+=s.charAt(m-1);
                
                if(i==1||i==nRows){
                    
                    if(i==1){m+=range;}
                    if(i==nRows){m+=2*(i-1);}
                }else {if(range == 2*(i-1)){
                        m+=range;
                        range=2*(nRows-i);
                    }else{
                        m+=range;
                        range=2*(i-1);
                    }}
            
            }
        }
        return ss;
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值