N字形变换 Golang leecode_6

首先还是暴力,先构建一个 numRows 行,1000列的二维数组,然后将字符串 s 变成字符数组按照 N 字形排列,然后再 Z 字形遍历,代码逐过程调试很好看懂。

package mainimport ("fmt"
)func convert(s string, numRows int) string {if numRows == 1 || numRows >= len(s) {return s}flag := 0  // 用来控制内嵌 for 循环的扫描方向count := 0 // 用作 bytes 字符数组的索引j := 0dp := make([][]byte, numRows)for i := range dp {dp[i] = make([]byte, 1000) // 调整大小以避免索引越界}bytes := []byte(s)for i := 0; i < 1000; i++ {for ; j < numRows && flag == 0; j++ {if count < len(bytes) {dp[j][i] = bytes[count]count++} else {break}}flag = 1i++for j = numRows - 2; j >= 0 && flag == 1; j-- {if count < len(bytes) {dp[j][i] = bytes[count]count++i++} else {break}}flag = 0i = i - 2j = 1if count >= len(bytes) {break}}// 构建结果字符串var res []bytefor n := 0; n < numRows; n++ {for m := 0; m < 1000; m++ {if dp[n][m] != 0 {res = append(res, dp[n][m])}}}return string(res)
}func main() {s := "PAYPALISHIRING"numRows := 3fmt.Println(convert(s, numRows))
}

用时 56ms(超过6.12%用户),内存消耗 6.83MB(超过49.92%的用户)。果然暴力不是最好的方法,看看有没有方法可以进行优化。看到了一个人的题解,思路和我的一样,但是对字符串和二维数组的操作比我牛逼的多,原谅我是golang 小白,下面是代码,很值得我学习

func convert(s string, numRows int) string {n, r := len(s), numRowsif r == 1 || r >= n {return s}t := r*2 - 2c := (n + t - 1) / t * (r - 1)mat := make([][]byte, r)for i := range mat {mat[i] = make([]byte, c)}x, y := 0, 0for i, ch := range s {mat[x][y] = byte(ch)if i%t < r-1 {x++ // 向下移动} else {x--y++ // 向右上移动}}ans := make([]byte, 0, n)for _, row := range mat {for _, ch := range row {if ch > 0 {ans = append(ans, ch)}}}return string(ans)
}作者:力扣官方题解
链接:https://leetcode.cn/problems/zigzag-conversion/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

该作者还有一个第二版的优化方案,是针对遍历大多数 0 浪费时间的优化,有空在看吧,佛系刷题

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

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

相关文章

MATLAB算法实战应用案例精讲-【图像处理】图像配准

目录 前言 知识储备 如何选择图像处理软件? OpenCV图像处理基础知识 图像的基本表示方法 像素处理

Mybatis入门(三)

作用域&#xff08;Scope&#xff09;和生命周期 对象生命周期和依赖注入框架 依赖注入框架可以创建线程安全的、基于事务的 SqlSession 和映射器&#xff0c;并将它们直接注入到你的 bean 中&#xff0c;因此可以直接忽略它们的生命周期。 如果对如何通过依赖注入框架使用 M…

【亚马逊云】基于EC2以 All-in-One 模式快速部署 KubeSphere 和 Kubernetes

文章目录 1. 云实例配置说明2. SSH连接云实例3. 查看系统版本4. 修改主机名5. 安装依赖项6. 安全组和DNS修改7. 下载KubeKey8. 同时安装Kubesphere和Kubernetes[可选]单独安装Kubernetes[可选]单独安装KubeSphere9. 验证KubeSphere安装结果10. 登录KubeSphere控制台[可选]安装K…

C/C++字节对齐

C/C字节对齐 C/C字节对齐1.G_PACKED2.1 pack(push)2.2 pack(1) 全部例子 C/C字节对齐 1.G_PACKED #ifdef __GNUC__#define G_PACKED( __Declaration__ ) __Declaration__ __attribute__((packed)) #else#define G_PACKED( __Declaration__ ) __pragma( pack(push,1)) __Decla…

sqli-labs靶场详解(less11-less16)

目录 less-11 less-12 less-13 less-14 less-15 less-16 提交参数后 动态参数不存在url中 存在于post表单中 于是在表单中进行注入点测试 先看一看这种提交数据的关卡输入提交后会有什么反应 unameadmin&passwdadmin&submitSubmit 输出 usernameadmin passwordadmin un…

seata集成springboot的一些错误小计

1 seata依赖没找到 dependencies.dependency.version for com.alibaba.cloud:spring-cloud-starter-alibaba-seata:jar is missing. line 126, column 21错误原因:未指定具体的seata版本 解决 <!-- https://mvnrepository.com/artifact/com.alibaba.cloud/spring-cloud-st…

Java中弗洛伊德三角

包含连续自然整数的直角三角形被称为弗洛伊德三角形&#xff0c;以计算机科学家罗伯特弗洛伊德的名字命名。它是通过按顺序放置数字而创建的&#xff0c;从顶部的 1 开始&#xff0c;每一行都比前一行多一个数字。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 …

uni-app图片上传

注意&#xff1a; 1、定义&#xff1a;fileList&#xff0c; 2、图片上传请求地址按照自己的修改 async afterReadList(event) { let lastFileIndex this.fileList.length - 1; let remainingCount lastFileIndex > 9 ? 0 : 10 - lastFileIndex; …

vuex的使用笔记

1.安装 npm安装 npm install vuexnext --saveyarn安装 yarn add vuexnext --save2.基本结构 import Vuex from vuexconst store createStore({ //状态&#xff1a;相当于vue中的data&#xff08;&#xff09; state() {return {name: 0,code:"",todos: [{ id: 1…

安卓横竖屏切换后,应用只展示半屏问题 AndroidAutoSize

项目使用的是这个屏幕适配框架&#xff1a;GitHub - JessYanCoding/AndroidAutoSize: &#x1f525; A low-cost Android screen adaptation solution (今日头条屏幕适配方案终极版&#xff0c;一个极低成本的 Android 屏幕适配方案). 最近需要做一个特殊设备的横竖屏切换适配&…

稳定视频扩散数据管理解密【stable video diffusion】

Stability AI 最近于 2023 年 11 月 21 日推出了其最新模型—稳定视频扩散&#xff08;SVD&#xff09;。视频生成模型的这一突破取决于数据管理的关键作用。 除了模型检查点之外&#xff0c;他们还发布了一份技术报告。 让我们在 Stability AI 的技术报告和一些引人注目的示例…

js的数组去重方法

目录 es6数组中对象去重 1. filter()用法 2. findIndex()用法 3. 去重 其他方法&#xff1a; 方法二&#xff1a;reduce()去重 1. reduce()用法 1.1 找出字符长度最长的数组成员。 1.2 扁平化二维数组 1.3 扁平化多维数组 三、总结方案&#xff1a; 使用Set&#xf…

我是如何找到人生第一个SRC漏洞的

免责声明&#xff1a;由于传播或利用此文所提供的信息、技术或方法而造成的任何直接或间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c; 文章作者不为此承担任何责任。 这是一篇新手文章。 因为参加了补天的公益SRC活动&#xff0c;需要提交第一个漏洞&#xff…

armv9的RME简介

快速链接: . 👉👉👉 个人博客笔记导读目录(全部) 👈👈👈 付费专栏-付费课程 【购买须知】:【精选】ARMv8/ARMv9架构入门到精通-[目录] 👈👈👈 — 适合小白入门【目录】ARMv8/ARMv9架构高级进阶-[目录]👈👈👈 — 高级进阶、小白勿买【加群】ARM/TEE…

基于SSM的咖啡销售系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SSM的咖啡销售系统,java项目。 ecli…

k8s-deployment控制器 5

K8s控制器是Kubernetes&#xff08;简称k8s&#xff09;系统中一个重要的组成部分&#xff0c;它是一个管理Pod的中间层&#xff0c;可以创建和管理多个Pod副本&#xff0c;确保它们按照预定的数量和行为进行运行。 通过编写yaml文件将信息全部存到etcd中&#xff0c;控制器通…

初学Flink 学后总结

最近开始学习Flink,一边学习一边记录,以下是基于【尚硅谷】Flink1.13实战教程总结的笔记,方便后面温习 目录 初始 Flink 一:基础概念 1.Flink是什么 2.Flink主要应用场景

《微信小程序开发从入门到实战》学习三十三

第四章 云开发 本章云开发技术的功能与使用&#xff0c;包括以下几点&#xff1a; 1.学习使用云开发控制台 2.学习云开发JSON数据库功能 3.学习云开文件存储功能 4.学习云函数功能 5.使用云开发技术实现投票小程序的服务端功能 投票小程序大部分已经实现。需要实现&#…

系统设计一些个人小结

一些要记得的数字 关于时间 1天 > 86400秒 关于存储 跟存储有关的K是1024&#xff0c;其它都是1000。下面的数字忽略1000和1024的区别。 1T > 10^12 1G > 10^9 1M > 10^6 1K > 10^3 1B > 10^9 关于网页 1个网页大小按10K估算。下载一个网页按2s估算。 关于…

高端制造业中的通用性超精密3D光学测量仪器

超精密光学3D测量仪器具有高精度、自动化程度高、实时反馈和范围广等优势。它能够实现微米级别的精确测量&#xff0c;能够精确测量产品的尺寸、形状和表面粗糙度等&#xff0c;具有广泛的应用价值和重要意义。 超精密光学3D测量仪器配备多种传感器、控制器和计算机系统&#…