首页 > 代码库 > LeetCode 06 ZigZag Conversion
LeetCode 06 ZigZag Conversion
https://leetcode.com/problems/zigzag-conversion/
水题纯考细心
题目:依照Z字形来把一个字符串写成矩阵,然后逐行输出矩阵。
O(n)能够处理掉
记i为行数
第0行和第numRow-1行。 ans += str[i+k*(numRows*2-2)], k=0,1,2,...
其它, 每一个Z字形(事实上仅仅是一竖一斜两条线)须要加上两个,下标见代码。
特殊处理:numRows=1的时候numRows*2-2==0 ,会死循环的。另外numRows=1的时候直接输出即可
#include <cstdio> #include <cstring> #include <iostream> using namespace std; class Solution {public: string convert(string s, int numRows) { string ret; if(numRows == 1){ return s; } for(int i=0; i<numRows; i++){ if(i == 0 || i == numRows-1){ int j=i; while(j<s.size()){ ret = ret + s[j]; j += numRows*2-2; } }else{ int j=i; while(j<s.size()){ ret = ret + s[j]; if(j+numRows*2-2-(i*2) < s.size())ret = ret + s[j+numRows*2-2-(i*2)]; j += numRows*2-2; } } } return ret; }}; int main(){ string s; int numRows; Solution sol; while(cin >> s >> numRows){ cout << sol.convert(s, numRows) << endl; } return 0; }
LeetCode 06 ZigZag Conversion
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。