【力扣6-Z字形变换零钱兑换】多种解法,模拟Z索引+模拟行索引(golang)

题目描述

https://leetcode-cn.com/problems/zigzag-conversion

思路题解

方法1:模拟Z索引

自己敲得,速度比较慢,思路就是建立一个数组,模拟整个过程:按Z字形(其实是N字形)插入-按行遍历数组-拼凑并返回结果。5% 5%

func convert(s string, numRows int) string {
	//0.特殊情况处理
	if numRows==1{
		return s
	}
	//1.开辟矩阵  高n*宽(len(s)%(n+n-2)+1)*(n-1)
	mod:=numRows+numRows-2 //一个N字的最小长度,不算右上方
	r, l := numRows, (len(s)/mod+1)*(numRows-1)
	m := make([][]string, r) // 行
	for i := range m {
		m[i] = make([]string, l) // 列
	}
	//2.赋值
	for i,v:=range s{
		if i%mod<numRows{
			m[i%mod][(i/mod)*(numRows-1)]=string(v)
		}else {
			m[mod-i%mod][(i/mod)*(numRows-1)+(i%mod-numRows+1)]=string(v)
		}
	}
	//3.横向遍历
	ans:=""
	for i:=0;i<len(m);i++{
		for j:=0;j<len(m[i]);j++{
			if m[i][j]!=""{
				ans=fmt.Sprintf("%v%v",ans,m[i][j])
			}
		}
	}
	return ans
}

方法2:模拟行索引

题解中大神的方法,因为只看列方向其变化是有规律的,即从0→n-1→0直接用flag标记方向,按行存储,最后遍历行即可。仿照着敲了个golang的代码

func convert(s string, numRows int) string {
	//0.特殊情况处理
	if numRows==1{
		return s
	}
	flag:=-1
	index:=0
	var m = make([]string, numRows) // 行
	for _,v:=range s{
		m[index]+=string(v)
		if index==0||index==numRows-1{
			flag=-flag
		}
		index=index+flag
	}
	return strings.Join(m,"")
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值