博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode]6. ZigZag Conversion
阅读量:5267 次
发布时间:2019-06-14

本文共 1153 字,大约阅读时间需要 3 分钟。

原题链接:

意思是给定输入字符串和行数,把字符串字符按照锯齿状排列后,按行从左到右输出目标字符串。

我的实现:

class Solution {public:    string convert(string s, int numRows) {        if (s.length() == 0)            return "";                vector
> storage(numRows); int count = 0, rowIndex = 0; bool direction = true; while (count < s.length()) { storage[rowIndex].push_back(s[count]); if (numRows > 1) { if (rowIndex >= numRows - 1 || rowIndex <= 0) direction = !direction; if (!direction) rowIndex++; else rowIndex--; } count++; } string result = ""; for (int i = 0; i < numRows; i++) { for (int j = 0; j < storage[i].size(); j++) { result = result + storage[i][j]; } } return result; }};

解释:zigzag排列字符是有规律的,我是以从顶点直线向下开始到达最下端,然后又斜向上直到最上端为一个周期,每一步向下行数+1, 向上行数-1,实现时注意触底和触顶的处理(错了好多次)。按行存字符,最后按行输出就行。

 

总结:字符串处理,边界条件判断,找规律

转载于:https://www.cnblogs.com/qianzixuan1996/p/8288372.html

你可能感兴趣的文章
Kafka学习笔记
查看>>
Octotree Chrome安装与使用方法
查看>>
Windows 环境下基于 Redis 的 Celery 任务调度模块的实现
查看>>
趣谈Java变量的可见性问题
查看>>
C# 强制关闭当前程序进程(完全Kill掉不留痕迹)
查看>>
ssm框架之将数据库的数据导入导出为excel文件
查看>>
语音识别中的MFCC的提取原理和MATLAB实现
查看>>
验证组件FluentValidation的使用示例
查看>>
0320-学习进度条
查看>>
解决windows系统的oracle数据库不能启动ora-00119和ora-00130的问题
查看>>
ip相关问题解答
查看>>
MetaWeblog API Test
查看>>
反弹SHELL
查看>>
关闭Chrome浏览器的自动更新和升级提示
查看>>
移动、尺寸改变
查看>>
poj2255Tree Recovery【二叉树重构】
查看>>
tcpcopy 流量复制工具
查看>>
vue和react的区别
查看>>
第十一次作业
查看>>
负载均衡策略
查看>>