6. ZigZag Conversion(之字形排列)

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

思路:

比如有一个字符串 “0123456789ABCDEF”,转为zigzag


image.png

除了第一行和最后一行没有形成之字形的数字外,其他的都有,不算中间的斜线部分,每行中相邻两个元素的index之差和行数是相关的,为size=2numRows-2,根据这个特点,可以按顺序找到所有黑色元素在字符串中的位置,将他们按顺序加到新字符串里。对于红色元素的位置为j+size-2i,其中j是前一个黑色元素的列数,i为当前行数。比如当n=4中的那个红色5,它的位置为1+6-2*1=5。当我们知道所有黑色元素和红色元素位置的正确算法,就可以一次性的把他们按顺序都加到新的字符串里边。

var convert = function(s, numRows) {
            if(numRows<=1) return s;
            var res='';
            var size=2*numRows-2;
            for (var i = 0; i < numRows; i++) {
                for (var j = i; j < s.length; j+=size) {
                    res+=s[j];
                    var tmp=j+size-2*i;
                    if(i!=0 && i!=numRows-1 && tmp<s.length) res+=s[tmp];
                }
            }
            return res;
        };
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,803评论 19 139
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,255评论 18 399
  • 暮春的天气,泛着些慵懒,尤其在这样的夜晚,灯火凄迷,你和一盏灯都不说话,选择沉默——这样的氛围或多或少让人有点恹恹...
    淮北师范大学陶培华阅读 3,878评论 0 6
  • 郭相麟 一个谈古论今,活跃在讲坛的学者,因常识性的口误而受到人们的质疑; 一个闪烁在银光灯下的主持人,因习惯于某种...
    郭相麟阅读 3,047评论 0 0

友情链接更多精彩内容