码迷,mamicode.com
首页 > 其他好文 > 详细

Letcode-6、Z字形变换

时间:2020-02-25 00:20:23      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:for   ||   ret   string   row   div   code   ring   break   

class Solution {
public:
    string convert(string s, int numRows) {
        string t;
        int len = s.length();
        int n;
        if (numRows > 2)         //这个地方要特殊处理一下,当是只有一行或是两行时候两列中间没有字母
            n = numRows * 2 - 2;
        else  n = numRows;
        for (int i = 0; i < numRows; i++) {
            if (i == 0 || i == numRows - 1) {
                int id = i;
                while (id < len) t+=s[id], id += n;                                                                                                                        
            }
            else {
                int id = i;
                while (id < len) {
                    t+= s[id];
                    id = id + (numRows - i-1)*2;
                    if (id < len) t+= s[id];
                    else break;
                    id = id + (i) * 2;
                }
            }
        }
        return t;
    }
};

Letcode-6、Z字形变换

标签:for   ||   ret   string   row   div   code   ring   break   

原文地址:https://www.cnblogs.com/chaiyinlei/p/12359499.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!