【LeetCode: Z 字形变换 + 模拟】

在这里插入图片描述

🚀 算法题 🚀

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域优质创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

🚀 算法题 🚀

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

🍔 目录

    • 🚩 题目链接
    • ⛲ 题目描述
    • 🌟 求解思路&实现代码&运行结果
      • ⚡ 模拟
        • 🥦 求解思路
        • 🥦 实现代码
        • 🥦 运行结果
    • 💬 共勉

🚩 题目链接

  • 6. Z 字形变换

⛲ 题目描述

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。

比如输入字符串为 “PAYPALISHIRING” 行数为 3 时,排列如下:

P A H N
A P L S I I G
Y I R
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“PAHNAPLSIIGYIR”。

请你实现这个将字符串进行指定行数变换的函数:

string convert(string s, int numRows);

示例 1:

输入:s = “PAYPALISHIRING”, numRows = 3
输出:“PAHNAPLSIIGYIR”
示例 2:
输入:s = “PAYPALISHIRING”, numRows = 4
输出:“PINALSIGYAHRPI”
解释:
P I N
A L S I G
Y A H R
P I
示例 3:

输入:s = “A”, numRows = 1
输出:“A”

提示:

1 <= s.length <= 1000
s 由英文字母(小写和大写)、‘,’ 和 ‘.’ 组成
1 <= numRows <= 1000

🌟 求解思路&实现代码&运行结果


⚡ 模拟

🥦 求解思路
  1. 通过一个List来存储numRows个StringBuilder,然后,记录俩个变量来分别维护当前走到了第几行,以及当前的方向。如果当前没有达到开始的位置或者结束的位置,在当前行添加元素,否则,就改变方向,继续重复该过程,直接字符串的结束位置。
  2. 详细的模拟实现过程记录到了代码中,请结合代码具体学习。
  3. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
class Solution {public String convert(String s, int numRows) {if (numRows == 1)return s;List<StringBuilder> rows = new ArrayList<>();// 通过循环生成每一行都要进行拼接的字符串StringBuilder()for (int i = 0; i < Math.min(numRows, s.length()); i++)rows.add(new StringBuilder());// 记录当前是第几行int curRow = 0;// 通过一个Boolean 变量来记录此时的方向:向上 向下boolean goingDown = false;// 遍历当前是字符串的字符for (char c : s.toCharArray()) {// 每一行的StringBuilder 分别进行拼接rows.get(curRow).append(c);// 处理边界的情况 如果是第零行,直接调整方向为向下// 如果是最后一行, 直接调整方向为向上if (curRow == 0 || curRow == numRows - 1)goingDown = !goingDown;// 如果此时的方向是向下,行数++,反之 方向相反 行数--curRow += goingDown ? 1 : -1;}// 最后通过一个最终的循环直接将所有的结果进行拼接展示StringBuilder ret = new StringBuilder();for (StringBuilder row : rows)ret.append(row);return ret.toString();// 返回最终的结果}
}
🥦 运行结果

在这里插入图片描述


💬 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/438307.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

产业需求大数据平台

产业需求大数据平台&#xff0c;依托大数据、NLP等技术&#xff0c;全面采集区域产业人才需求数据&#xff0c;从宏观、中观、微观三个层面对产业需求进行分析&#xff0c;并匹配学校自身的办学定位、专业布局、人才培养目标、培养规格和课程设置&#xff0c;进行专业设置匹配度…

MySQL-进阶-存储引擎

一、MySQL体系结构 二、存储引擎简介 三、存储引擎特点 1、InnoDB 2、MyISAM 3、Memory 四、存储引擎选择

如何发现帕鲁私服漏洞

白天当帕鲁、晚上抓帕鲁 相信所有的帕鲁玩家都不希望辛辛苦苦肝了几百小时抓的帕鲁因为网络入侵消失&#xff0c;除了抵御游戏内的强盗入侵&#xff0c;还要抵御现实世界的网络入侵&#xff0c;原本单纯的帕鲁变的复杂无比。 服务器弱口令、服务漏洞、未授权访问等入侵手段&a…

STM32学习笔记(三) —— GPIO点亮LED

1.GPIO简介 GPIO&#xff0c;全称是General-purpose input/output&#xff08;通用输入输出&#xff09;。在单片机中是表示能被控制的引脚&#xff0c;能检测输入信号的高低电平&#xff0c;也能输出高低电平控制外部设备。STM32F103RCT6一共有64个引脚&#xff0c;其中有51个…

二维数组的学习

前言 在前面我们学习了一维数组&#xff0c;但是有的问题需要用二位数组来解决。 二维数组常称为矩阵&#xff0c;把二维数组写成行和列的排列形式&#xff0c;可以有助于形象化的理解二维数组的逻辑结构。 一、二维数组的定义 二维数组定义的一般格式&#xff1a; 数据类型 数…

Mac安装及配置MySql

Mac下载配置MySql mysql下载及安装 下载地址&#xff1a;https://dev.mysql.com/downloads/mysql/ 根据自己电脑确定下载x86还是ARM版本的 如果不确定&#xff0c;可以查看自己电脑版本&#xff0c;终端输入命令 uname -a 点击Download下载&#xff0c;可跳过登录注册&…

笨蛋总结JVM

笨蛋总结JVM 由于Java语言将自己的内存控制权交给了虚拟机&#xff0c;所以需要了解虚拟机的运行机制 &#xff08;主要用于回顾JVM&#xff09; 笨蛋总结JVM 笨蛋总结JVM1.运行时数据区域线程私有区域程序计数器Java虚拟机栈本地方法栈 线程共享区域堆方法区 1.2程序计数器…

ctfshow web71

开启环境&#xff1a; c?><?php $anew DirectoryIterator("glob:///*"); foreach($a as $f) {echo($f->__toString(). );} exit(0); ?> cinclude("/flagc.txt");exit();

SD-WAN技术:异地组网监控的革新之选

在当今数字化的商业环境中&#xff0c;企业对于远程监控的需求日益增长。无论是分支机构的管理&#xff0c;还是跨地域的项目协作&#xff0c;稳定、高效的网络监控系统都显得至关重要。然而&#xff0c;异地组网监控面临着数据传输、设备兼容性、安全性等一系列挑战。在这一背…

GUN/Linux时间同步服务之chrony配置管理

风险告知 本人及本篇博文不为任何人及任何行为的任何风险承担责任&#xff0c;图解仅供参考&#xff0c;请悉知&#xff01;相关配置操作是在一个全新的演示环境下进行的&#xff0c;演示环境中没有任何有价值的数据&#xff0c;但这并不代表摆在你面前的环境也是如此。生产环境…

springboot设置热部署

目录 以下是实现 Spring Boot 热部署的方法&#xff1a; 1、添加依赖 2、配置 IDE 3、配置 application.properties 或 application.yml 4、启动应用 Spring Boot 提供了开发者进行热部署的支持。在开发过程中&#xff0c;每次修改代码后&#xff0c;需要重启应用才能看到…

阿里云国际OpenAPI多接口快速管理ECS服务器教程

阿里云OpenAPI提供了多种接口来管理ECS实例&#xff0c;包括创建、删除、重启等操作。但是&#xff0c;对于执行命令并获取结果的需求&#xff0c;需要使用ECS的远程连接功能来实现。 具体来说&#xff0c;你可以使用ECS的SSH客户端连接到ECS实例上&#xff0c;并在实例上执行所…