力扣题目-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();
    }
}
相关文章
|
30天前
|
存储 算法 Serverless
【C/C++ 数据结构】深入探索数据结构中算法复杂度:从C++和数学的视角
【C/C++ 数据结构】深入探索数据结构中算法复杂度:从C++和数学的视角
46 0
|
18天前
|
人工智能 机器人 C++
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
【C++/Python】Windows用Swig实现C++调用Python(史上最简单详细,80岁看了都会操作)
|
1月前
|
编译器 测试技术 C++
【Python 基础教程 01 全面介绍】 Python编程基础全攻略:一文掌握Python语法精髓,从C/C++ 角度学习Python的差异
【Python 基础教程 01 全面介绍】 Python编程基础全攻略:一文掌握Python语法精髓,从C/C++ 角度学习Python的差异
167 0
|
23小时前
|
存储 SQL 缓存
阿里云大学考试python中级题目及解析-python中级
阿里云大学考试python中级题目及解析-python中级
|
7天前
|
前端开发 Java Go
开发语言详解(python、java、Go(Golong)。。。。)
开发语言详解(python、java、Go(Golong)。。。。)
|
19天前
|
安全 数据安全/隐私保护 Python
292: 程序设计C 实验五 题目三 设计密码(python)
292: 程序设计C 实验五 题目三 设计密码(python)
|
24天前
|
C++ Python
【C++/Python】C++调用python文件
【C++/Python】C++调用python文件
|
1月前
|
SQL Java 关系型数据库
在Python中编写Java数据库驱动是不可能的
在Python中编写Java数据库驱动是不可能的
|
1月前
|
人工智能 Java 开发者
Python与Java:两大编程语言的联系与区别
Python与Java:两大编程语言的联系与区别
36 2
|
1月前
|
Java API PHP
多多关键字API php java Python
多多关键字API接口广泛应用于商家进行市场分析、竞品分析、关键词优化等场景。商家可以通过分析关键词数据,了解用户需求,制定针对性的营销策略,提高产品的曝光率和转化率。

热门文章

最新文章