|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
题目描述:
- 将一个给定字符串根据给定的行数,以从上往下、从左到右进行 Z 字形排列。
- 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:
- L C I R
- E T O E S I I G
- E D H N
- 之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。
- 请你实现这个将字符串进行指定行数变换的函数:
- string convert(string s, int numRows);
- 示例 1:
- 输入: s = "LEETCODEISHIRING", numRows = 3
- 输出: "LCIRETOESIIGEDHN"
- 示例 2:
- 输入: s = "LEETCODEISHIRING", numRows = 4
- 输出: "LDREOEIIECIHNTSG"
- 解释:
- L D R
- E O E I I
- E C I H N
- T S G
- 来源:力扣(LeetCode)
- 链接:https://leetcode-cn.com/problems/zigzag-conversion
- 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
复制代码
- class Solution {
- public:
- string convert(string s, int numRows) {
- if(s.size() <= 2 || numRows == 1) return s;
- vector<string> store(numRows, "");
- int i = 0, flag = -1;
- for(auto cha : s){
- store[i].push_back(cha);
- if(i == 0 || i == numRows - 1) flag = -flag;
- i += flag;
- }
- string res;
- for(auto cha : store) res += cha;
- return res;
- }
- };
复制代码
参考链接:https://leetcode-cn.com/problems ... g-bian-huan-by-jyd/ |
|