力扣题目-Z字形变幻(数学规律法、hash法,c++,python,Java实现)

简介: 力扣题目-Z字形变幻(数学规律法、hash法,c++,python,Java实现)

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


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

L   C   I   R
E T O E S I I G
E   D   H   N


之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:“LCIRETOESIIGEDHN”。


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

string convert(string s, int numRows);
示例 1:
输入: s = "LEETCODEISHIRING", numRows = 3
输出: "LCIRETOESIIGEDHN"
示例 2:
输入: s = "LEETCODEISHIRING", numRows = 4
输出: "LDREOEIIECIHNTSG"
解释:
L     D     R
E   O E   I I
E C   I H   N
T     S     G


C++


1.数学规律

这道题只是需要相应的字符串,不要求输出,明显难度降低了,因为这个图像是有规律的,发现每一满列对于行元素到下一满列对应行的元素距离是固定的,为k= (numRows-1)*2,我们便可以以此为基础,逐行添加字符。

时间复杂度实际是遍历一趟字符串s为O(n),空间复杂度O(n)

class Solution {
public:
    string convert(string s, int numRows) {
        string ans;
        if(numRows<2)return s;
        int n=s.size();
        for(int i=0;i<numRows&&i<n;i++){
            int k=i;
            while(k<n){
                ans+=s[k];
                k+=(numRows-1)*2;
               if(i!=0&&i!=numRows-1){
                   if(k-i*2<n)
                   ans+=s[k-i*2];
               }
            }
        }
        return ans;
    }
};


2.hash法

由于解1已经达到了我感觉的时空最简,我没有想出第二种方法,后看题解后,题解还有一种方法是按Z字型遍历s,将字符保存在对应行中;实际上这是一种hash思想,可以用vector还是实现,但是空间开销要比解法1大,时间复杂度不变

class Solution {
public:
    string convert(string s, int numRows) {
        if(numRows<2)return s;
        int n=s.size();
        vector<string> hash(min(numRows,n));
        int k,f;
        k=0;
        for(int i=0;i<n;i++){
            if(k==0)f=1;
            if(k==numRows-1)f=-1;
            hash[k]+=s[i];
            k+=f;
        }
        string ans;
        for(string c:hash)ans+=c;
        return ans;
    }
};


Python


1.数学规律

class Solution:
    def convert(self, s: str, numRows: int) -> str:
        if numRows==1:
            return s
        ans=""
        n=len(s)
        for i in range(numRows):
            k=i
            while k<n:
                ans+=s[k]
                k+=2*(numRows-1)
                if i!=0 and i!=numRows-1 and k-2*i <n:
                    ans+=s[k-2*i]
        return ans


2.hash

class Solution:
    def convert(self, s: str, numRows: int) -> str:
        if numRows==1:
            return s
        hashrow=["" for _ in range(numRows)]
        k=0
        flag=1
        for c in s:
            if k==0:
                flag=1
            if k==numRows-1:
                flag=-1
            hashrow[k]+=c
            k+=flag   
        return "".join(hashrow)


java


class Solution {
    public String convert(String s, int numRows) {
        if(numRows ==1)  return s;
        StringBuilder ans=new StringBuilder();
        int n=s.length();
        for (int i=0;i<numRows;i++){
            int k=i;
            while(k<n){
                ans.append(s.charAt(k));
                k+=2*(numRows-1);
                if(i!=0&&i!=numRows-1&&k-2*i<n)
                 ans.append(s.charAt(k-2*i));
            }
        }
        return ans.toString();
    }
}
class Solution {
    public String convert(String s, int numRows) {
        int n=s.length();
        if(numRows==1 ||numRows>n) return s;
        StringBuilder[] row=new StringBuilder[numRows+1];
        for(int i=0;i<=numRows;i++)
         row[i]=new StringBuilder();
        int k=0,flag=1;
        for(int i=0;i<n;i++){
            if(k==0)flag=1;
            if(k==numRows-1)flag=-1;
            row[k].append(s.charAt(i));
            k+=flag;
        }
        for(int i=0;i<numRows;i++)
       row[numRows].append(row[i]);
       return row[numRows].toString();
    }
}
相关文章
|
5月前
|
存储 负载均衡 算法
我们来说一说 Java 的一致性 Hash 算法
我是小假 期待与你的下一次相遇 ~
200 1
|
7月前
|
数据采集 自然语言处理 Java
Playwright 多语言一体化——Python/Java/.NET 全栈采集实战
本文以反面教材形式,剖析了在使用 Playwright 爬取懂车帝车友圈问答数据时常见的配置错误(如未设置代理、Cookie 和 User-Agent),并提供了 Python、Java 和 .NET 三种语言的修复代码示例。通过错误示例 → 问题剖析 → 修复过程 → 总结教训的完整流程,帮助读者掌握如何正确配置爬虫代理及其它必要参数,避免 IP 封禁和反爬检测,实现高效数据采集与分析。
460 3
Playwright 多语言一体化——Python/Java/.NET 全栈采集实战
|
5月前
|
JSON JavaScript 前端开发
Python+JAVA+PHP语言,苏宁商品详情API
调用苏宁商品详情API,可通过HTTP/HTTPS发送请求并解析响应数据,支持多种编程语言,如JavaScript、Java、PHP、C#、Ruby等。核心步骤包括构造请求URL、发送GET/POST请求及解析JSON/XML响应。不同语言示例展示了如何获取商品名称与价格等信息,实际使用时请参考苏宁开放平台最新文档以确保兼容性。
|
8月前
|
数据采集 自然语言处理 JavaScript
Playwright多语言生态:跨Python/Java/.NET的统一采集方案
随着数据采集需求的增加,传统爬虫工具如Selenium、Jsoup等因语言割裂、JS渲染困难及代理兼容性差等问题,难以满足现代网站抓取需求。微软推出的Playwright框架,凭借多语言支持(Python/Java/.NET/Node.js)、统一API接口和优异的JS兼容性,解决了跨语言协作、动态页面解析和身份伪装等痛点。其性能优于Selenium与Puppeteer,在学术数据库(如Scopus)抓取中表现出色。行业应用广泛,涵盖高校科研、大型数据公司及AI初创团队,助力构建高效稳定的爬虫系统。
467 2
Playwright多语言生态:跨Python/Java/.NET的统一采集方案
|
数据采集 缓存 Java
Python vs Java:爬虫任务中的效率比较
Python vs Java:爬虫任务中的效率比较
|
6月前
|
Java C++
力扣第一道困难题《3. 无重复字符的最长子串》,c++
首先我们看到这个题是肯定有一种暴力的硬解思路的,那就是将两个vector直接链接起来,然后再排序后,直接返回中间值,这个方法实现起来还是非常容易的,
170 0
|
机器学习/深度学习 人工智能 自然语言处理
比较Python和Java哪个更好
比较Python和Java哪个更好
413 5
|
机器学习/深度学习 人工智能 安全
python和Java的区别以及特性
Python:适合快速开发、易于维护、学习成本低、灵活高效。如果你需要快速上手,写脚本、数据处理、做点机器学习,Python就是你的首选。 Java:适合大型项目、企业级应用,性能要求较高的场景。它类型安全、跨平台能力强,而且有丰富的生态,适合更复杂和规模化的开发。
691 3
|
安全 Java Python
基于python-django的Java网站全站漏洞检测系统
基于python-django的Java网站全站漏洞检测系统
173 0
|
算法 Java
LeetCode(一)Java
LeetCode(一)Java
165 0

推荐镜像

更多