leetcode ZigZag Conversion

刚开始看完题目之后,按照列出来的形式,一直将变型之后的数组当做一个二位数组形式,所以就想着先把输入的字符串按照条件变成一个二维数组,然后再将成型的二维数组转换成字符串。但是显然这样很复杂,而且我也没有做出来。思路有错!!

百度之后,思路都是:直接用一个一维数组按照ZigZag顺序接收字符串的字符。这样就需要推算出是按照怎样的先后顺序获取字符串数组的。

对于第一行和最后一行比较简单,所取的字符之间的间隔是固定的,也就是2(numRows-1),不过需要注意的是,第一行的起始字符也就是字符串里面的第一个;而最后一行的起始字符是第numRows-1个。

对于中间行,他们之间的间隔是不固定的,也就是:numRows-2i, 2i,​numRows-2i,2i,​numRows-2i, 2i......(其中i是指第i行)

对于这种间隔不一定的循环,所采取的措施是:

​inter=2*i;  

for(j=i ; j<str.length-1;j+=inter){ inter=interval-inter;}

那如果连个字符之间的间隔是每三个重复呢?循环的时候又应该是怎么写?​

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值