前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日一道leetcode:6. N 字形变换

每日一道leetcode:6. N 字形变换

作者头像
felixzhao
发布2023-04-06 11:52:28
1670
发布2023-04-06 11:52:28
举报
文章被收录于专栏:null的专栏

1. 题目(中等)

题目链接

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2. 分析与解答

思路:矩阵模拟。分为两步:

  • 向下遍历
  • 向右上遍历
代码语言:javascript
复制
class Solution {
public:
    string convert(string s, int numRows) {
        // 模拟
        int n = s.length();
        if (numRows == 1 || numRows >= n) {
            return s;
        }
        vector<vector<char>> vec(numRows, vector<char>(n));
        int i = 0, j = 0, k = 0;
        
        // 向下走
        while (k < n) {
            while (i < numRows-1 && k < n) {
                vec[i][j] = s[k];
                i ++;
                k ++;
            }

            while (i > 0 && k < n) {
                vec[i][j] = s[k];
                i --;
                j ++;
                k ++;
            }
        }

        string res = "";
        for (int x = 0; x < numRows; x++) {
            for (int y = 0; y < n; y++) {
                if (vec[x][y]) res += vec[x][y];
            }
        }
        return res;
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-04-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目(中等)
  • 2. 分析与解答
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档