Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >2023-04-28:将一个给定字符串 s 根据给定的行数 numRows以从上往下、从左到右进行 Z 字形排列比如输入字符串为

2023-04-28:将一个给定字符串 s 根据给定的行数 numRows以从上往下、从左到右进行 Z 字形排列比如输入字符串为

作者头像
福大大架构师每日一题
发布于 2023-06-09 02:06:10
发布于 2023-06-09 02:06:10
28400
代码可运行
举报
运行总次数:0
代码可运行

2023-04-28:将一个给定字符串 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)。

答案2023-04-28:

算法过程大体可以分为以下步骤:

1.计算给定字符串 s 的长度 n 和指定行数 numRows。

2.如果 numRows 等于 1 或者 numRows 大于等于 n,则返回原始字符串 s。

3.计算一个周期 t,其值为 2 * (numRows - 1)。

4.创建一个字符数组 ans,其长度与输入字符串 s 相同,并用空格符初始化。

5.根据 Z 字形排列的规律,按顺序遍历每一行 i(从第 0 行到第 numRows-1 行)及其对应的列 j(每一列长度为 t)。在遍历的过程中,根据当前所在行的位置 i 和周期 t,计算出对应列的顶部的行号 nextColTop。

6.对于每个字符 s[j],将其填入字符数组 ans 中,并将 fill 指针向后移动一位。如果该字符所在的行不是第 0 行和最后一行,并且在下一个周期中对应的位置 nextColTop-i 小于字符串的长度 n,则将 s[nextColTop-i] 也填入 ans 数组中,并将 fill 指针再次向后移动一位。

7.遍历完所有行和列后,将字符数组 ans 转换为字符串并返回。

时间复杂度:O(n),其中 n 是字符串 s 的长度。我们只需要遍历一次字符串 s。

空间复杂度:O(n),我们需要使用一个字符数组 ans 存储变换后的字符串,数组的大小为输入字符串 s 的长度 n。另外,我们还使用了常数级别的额外空间存储变换时需要的一些变量。

go完整代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package main

import "fmt"

func convert(s string, row int) string {
    n := len(s)
    if row == 1 || row >= n {
        return s
    }
    t := 2 * (row - 1)
    ans := make([]byte, n)
    fill := 0
    for i := 0; i < row; i++ {
        nextColTop := t
        for j := i; j < n; j += t {
            ans[fill] = s[j]
            fill++
            if i >= 1 && i <= row-2 && nextColTop-i < n {
                ans[fill] = s[nextColTop-i]
                fill++
            }
            nextColTop += t
        }
    }
    return string(ans)
}

func main() {
    s := "PAYPALISHIRING"
    result := convert(s, 3)
    fmt.Println(result)
}

在这里插入图片描述

rust完整代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
fn convert(s: String, row: i32) -> String {
    let n = s.chars().count();
    if row == 1 || row >= n as i32 {
        return s;
    }
    let t = 2 * (row - 1);
    let mut ans: Vec<char> = vec![' '; n];
    let mut fill = 0;
    for i in 0..row {
        let mut next_col_top = t;
        for j in (i as usize..n).step_by(t as usize) {
            ans[fill] = s.chars().nth(j).unwrap();
            fill += 1;
            if i >= 1 && i <= row - 2 && next_col_top - i < n as i32 {
                ans[fill] = s.chars().nth((next_col_top - i) as usize).unwrap();
                fill += 1;
            }
            next_col_top += t;
        }
    }
    ans.iter().collect()
}

fn main() {
    let s = "PAYPALISHIRING".to_string();
    let result = convert(s, 3);
    println!("{}", result);
}

在这里插入图片描述

c++完整代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <iostream>
#include <string>

using namespace std;

string convert(string s, int row) {
    int n = s.length();
    if (row == 1 || row >= n) {
        return s;
    }
    int t = 2 * (row - 1);
    string ans(n, ' ');
    int fill = 0;
    for (int i = 0; i < row; i++) {
        int nextColTop = t;
        for (int j = i; j < n; j += t, nextColTop += t) {
            ans[fill++] = s[j];
            if (i >= 1 && i <= row - 2 && nextColTop - i < n) {
                ans[fill++] = s[nextColTop - i];
            }
        }
    }
    return ans;
}

int main() {
    string s = "PAYPALISHIRING";
    string result = convert(s, 3);
    cout << result << endl; 
    return 0;
}

在这里插入图片描述

c完整代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* convert(char* s, int row) {
    int n = strlen(s);
    if (row == 1 || row >= n) {
        return s;
    }
    int t = 2 * (row - 1);
    char* ans = (char*)malloc(sizeof(char) * (n + 1));
    memset(ans, ' ', sizeof(char) * n);
    int fill = 0;
    for (int i = 0; i < row; i++) {
        int nextColTop = t;
        for (int j = i; j < n; j += t, nextColTop += t) {
            ans[fill++] = s[j];
            if (i >= 1 && i <= row - 2 && nextColTop - i < n) {
                ans[fill++] = s[nextColTop - i];
            }
        }
    }
    ans[n] = '\0';
    return ans;
}

int main() {
    char s[] = "PAYPALISHIRING";
    char* result = convert(s, 3);
    printf("%s\n", result); 
    free(result);
    return 0;
}

在这里插入图片描述

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-04-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 福大大架构师每日一题 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
2022-12-10:给你一个由小写字母组成的字符串 s ,和一个整数 k 如果满足下述条件,则可以将字符串 t 视作是 理想字符串 : t 是字符串 s 的一
2022-12-10:给你一个由小写字母组成的字符串 s ,和一个整数 k如果满足下述条件,则可以将字符串 t 视作是 理想字符串 :t 是字符串 s 的一个子序列。t 中每两个 相邻 字母在字母表中位次的绝对差值小于或等于 k 。返回 最长 理想字符串的长度。字符串的子序列同样是一个字符串,并且子序列还满足:可以经由其他字符串删除某些字符(也可以不删除)但不改变剩余字符的顺序得到。注意:字母表顺序不会循环例如,'a' 和 'z' 在字母表中位次的绝对差值是 25,而不是 1 。答案2022-12-10:二
福大大架构师每日一题
2022/12/10
6290
2022-12-10:给你一个由小写字母组成的字符串 s ,和一个整数 k 如果满足下述条件,则可以将字符串 t 视作是 理想字符串 : t 是字符串 s 的一
2023-08-20:用go语言写算法。给定一个由'W'、'A'、'S'、'D'四种字符组成的字符串,长度一定是4的倍数, 你
2023-08-20:用go语言写算法。给定一个由'W'、'A'、'S'、'D'四种字符组成的字符串,长度一定是4的倍数,
福大大架构师每日一题
2023/08/29
1730
2023-08-20:用go语言写算法。给定一个由'W'、'A'、'S'、'D'四种字符组成的字符串,长度一定是4的倍数,  你
2023-07-07:给出两个字符串 str1 和 str2。 返回同时以 str1 和 str2 作为子序列的最短字符串。 如
2.创建一个二维数组 dp,其大小为 (n+1) x (m+1),其中 n 是 str1 的长度,m 是 str2 的长度。
福大大架构师每日一题
2023/07/25
1780
2023-07-07:给出两个字符串 str1 和 str2。 返回同时以 str1 和 str2 作为子序列的最短字符串。 如
2022-12-04:给定一个由 ‘[‘ ,‘]‘,‘(‘,‘)’ 组成的字符串, 请问最少插入多少个括号就能使这个字符串的所有括号左右配对, 例如当前串是 “
2022-12-04:给定一个由 '' ,'','(',‘)’ 组成的字符串,请问最少插入多少个括号就能使这个字符串的所有括号左右配对,例如当前串是 "([[])",那么插入一个']'即可满足。输出最少插入多少个括号。答案2022-12-04:递归。很多人会想到栈,在这里行不通的。可能性1,先搞定l+1...r,然后搞定l。可能性2,先搞定l...r-1,然后搞定r。可能性3,sl和sr天然匹配,需要搞定的就是l+1..r-1。递归这三种可能性取最小值即可。代码用rust编写。代码如下:use std::{
福大大架构师每日一题
2022/12/04
4910
2022-12-04:给定一个由 ‘[‘ ,‘]‘,‘(‘,‘)’ 组成的字符串, 请问最少插入多少个括号就能使这个字符串的所有括号左右配对, 例如当前串是 “
2023-05-27:给你一个只包含小写英文字母的字符串 s 。 每一次 操作 ,你可以选择 s 中两个 相邻 的字符,并将它们交换。 请你返回将 s 变成回文
1.定义结构体 IndexTree,其中包含一个整型切片 tree 和整型变量 n,用于实现树状数组。
福大大架构师每日一题
2023/05/27
3670
2022-11-26:给定一个字符串s,只含有0~9这些字符 你可以使用来自s中的数字,目的是拼出一个最大的回文数 使用数字的个数,不能超过s里含有的个数 比如
力扣2384。统计词频,先从大网校填写一对一对的数据,然后填写剩下的最大的数据,最后组合就是需要的返回值。注意取一对数的时候刚开始不能取0,因为起始为0的数不是回文数。
福大大架构师每日一题
2022/11/26
3760
2022-11-26:给定一个字符串s,只含有0~9这些字符 你可以使用来自s中的数字,目的是拼出一个最大的回文数 使用数字的个数,不能超过s里含有的个数 比如
Leetcode算法系列| 6. Z 字形变换
游戏开发小Y
2024/01/18
1150
Leetcode算法系列| 6. Z 字形变换
2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。 需保证 返回结果的
2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。
福大大架构师每日一题
2023/11/30
2740
2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。 需保证 返回结果的
一起学Rust-实战leetcode(三)
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"LCIRETOESIIGEDHN"。
江湖安得便相忘
2019/09/16
5930
每日一练-单词接龙、矩阵中的最长递增路径、Z 字形变换
我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=1k2biw8u5kw2
共饮一杯无
2022/11/28
2400
每日一练-单词接龙、矩阵中的最长递增路径、Z 字形变换
Leetcode 6. Z 字形变换
比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下:
静谧星空TEL
2021/04/27
4790
2023-06-28:你想要用小写字母组成一个目标字符串 target。 开始的时候,序列由 target.length 个 ‘
如果可以印出序列,那么返回一个数组,该数组由每个回合中被印下的最左边字母的索引组成
福大大架构师每日一题
2023/07/09
1550
2023-06-28:你想要用小写字母组成一个目标字符串 target。 开始的时候,序列由 target.length 个 ‘
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
2023-03-31:给定一个字符串 s,返回 s 中不同的非空 回文子序列 个数,
福大大架构师每日一题
2023/03/31
1.3K0
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
2023-03-31:给定一个字符串 s,返回 s 中不同的非空 回文子序列 个数,
福大大架构师每日一题
2023/06/08
3910
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
2022-11-01:给定一个只由小写字母和数字字符组成的字符串str。 要求子串必须只含有一个小写字母,数字字符数量随意。 求这样的子串最大长度是多少?
2022-11-01:给定一个只由小写字母和数字字符组成的字符串str。 要求子串必须只含有一个小写字母,数字字符数量随意。 求这样的子串最大长度是多少? 答案2022-11-01: 经典的滑动窗口问题。 时间复杂度:O(N)。 空间复杂度:O(1)。 代码用rust编写。代码如下: use rand::Rng; fn main() { let nn: i32 = 100; let test_time: i32 = 10000; println!("测试开始"); for _
福大大架构师每日一题
2022/11/01
3630
2022-11-01:给定一个只由小写字母和数字字符组成的字符串str。 要求子串必须只含有一个小写字母,数字字符数量随意。 求这样的子串最大长度是多少?
LeetCode - #6 字符串“之”字形转换
我们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。微博:@故胤道长[1])的 Swift 算法题题解整理为文字版以方便大家学习与阅读。
Swift社区
2021/11/26
4040
LeetCode - #6 字符串“之”字形转换
2023-05-22:给定一个长度为 n 的字符串 s ,其中 s[i] 是: D 意味着减少; I 意味着增加。 有效排列 是对有 n + 1 个在 [0,
有效排列 是对有 n + 1 个在 0, n 范围内的整数的一个排列 perm ,使得对所有的 i:
福大大架构师每日一题
2023/05/22
4730
2023-03-22:给定一个字符串str, 如果删掉连续一段子串,剩下的字符串拼接起来是回文串, 那么该删除叫做有效的删除。 返回有多少种有效删除。 注意 :
首先,我们来看如何判断一个字符串是否是回文串。我们可以使用双指针法,即左右指针分别指向字符串的头部和尾部,然后向中间扫描,逐个比较对应位置上的字符。若对应位置上的字符不相等,则该字符串不是回文串;否则,该字符串是回文串。
福大大架构师每日一题
2023/03/22
6190
2023-03-22:给定一个字符串str, 如果删掉连续一段子串,剩下的字符串拼接起来是回文串, 那么该删除叫做有效的删除。 返回有多少种有效删除。 注意 :
2023-01-06:给定一个只由小写字母组成的字符串str,长度为N, 给定一个只由0、1组成的数组arr,长度为N, arr[i] == 0表示str中i位
2023-01-06:给定一个只由小写字母组成的字符串str,长度为N,给定一个只由0、1组成的数组arr,长度为N,arri等于 0 表示str中i位置的字符不许修改,arri 等于 1表示str中i位置的字符允许修改,给定一个正数m,表示在任意允许修改的位置,可以把该位置的字符变成a~z中的任何一个,可以修改m次。返回在最多修改m次的情况下,全是一种字符的最长子串是多长。1 <= N, M <= 10^5,所有字符都是小写。来自字节。答案2023-01-06:尝试全变成a一直到全变成z,遍历26次。每次
福大大架构师每日一题
2023/01/06
1.1K0
2023-01-06:给定一个只由小写字母组成的字符串str,长度为N, 给定一个只由0、1组成的数组arr,长度为N, arr[i] == 0表示str中i位
2024-10-26:最长公共后缀查询。用go语言,给定两个字符串数组 wordsContainer 和 wordsQuery,
2024-10-26:最长公共后缀查询。用go语言,给定两个字符串数组 wordsContainer 和 wordsQuery,要对每个 wordsQuery[i] 找到一个与其有最长公共后缀的字符串。如果有多个字符串与 wordsQuery[i] 有相同的最长公共后缀,则返回在 wordsContainer 中最早出现的那个。最后,返回一个整数数组 ans,其中 ans[i] 表示与 wordsQuery[i] 有最长公共后缀的字符串在 wordsContainer 中的下标。
福大大架构师每日一题
2024/10/29
720
2024-10-26:最长公共后缀查询。用go语言,给定两个字符串数组 wordsContainer 和 wordsQuery,
推荐阅读
2022-12-10:给你一个由小写字母组成的字符串 s ,和一个整数 k 如果满足下述条件,则可以将字符串 t 视作是 理想字符串 : t 是字符串 s 的一
6290
2023-08-20:用go语言写算法。给定一个由'W'、'A'、'S'、'D'四种字符组成的字符串,长度一定是4的倍数, 你
1730
2023-07-07:给出两个字符串 str1 和 str2。 返回同时以 str1 和 str2 作为子序列的最短字符串。 如
1780
2022-12-04:给定一个由 ‘[‘ ,‘]‘,‘(‘,‘)’ 组成的字符串, 请问最少插入多少个括号就能使这个字符串的所有括号左右配对, 例如当前串是 “
4910
2023-05-27:给你一个只包含小写英文字母的字符串 s 。 每一次 操作 ,你可以选择 s 中两个 相邻 的字符,并将它们交换。 请你返回将 s 变成回文
3670
2022-11-26:给定一个字符串s,只含有0~9这些字符 你可以使用来自s中的数字,目的是拼出一个最大的回文数 使用数字的个数,不能超过s里含有的个数 比如
3760
Leetcode算法系列| 6. Z 字形变换
1150
2023-11-29:用go语言,给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。 需保证 返回结果的
2740
一起学Rust-实战leetcode(三)
5930
每日一练-单词接龙、矩阵中的最长递增路径、Z 字形变换
2400
Leetcode 6. Z 字形变换
4790
2023-06-28:你想要用小写字母组成一个目标字符串 target。 开始的时候,序列由 target.length 个 ‘
1550
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
1.3K0
2023-03-31:如何计算字符串中不同的非空回文子序列个数?
3910
2022-11-01:给定一个只由小写字母和数字字符组成的字符串str。 要求子串必须只含有一个小写字母,数字字符数量随意。 求这样的子串最大长度是多少?
3630
LeetCode - #6 字符串“之”字形转换
4040
2023-05-22:给定一个长度为 n 的字符串 s ,其中 s[i] 是: D 意味着减少; I 意味着增加。 有效排列 是对有 n + 1 个在 [0,
4730
2023-03-22:给定一个字符串str, 如果删掉连续一段子串,剩下的字符串拼接起来是回文串, 那么该删除叫做有效的删除。 返回有多少种有效删除。 注意 :
6190
2023-01-06:给定一个只由小写字母组成的字符串str,长度为N, 给定一个只由0、1组成的数组arr,长度为N, arr[i] == 0表示str中i位
1.1K0
2024-10-26:最长公共后缀查询。用go语言,给定两个字符串数组 wordsContainer 和 wordsQuery,
720
相关推荐
2022-12-10:给你一个由小写字母组成的字符串 s ,和一个整数 k 如果满足下述条件,则可以将字符串 t 视作是 理想字符串 : t 是字符串 s 的一
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验