面试经典150题(20)

leetcode 150道题 计划花两个月时候刷完,今天(第八天)完成了1道(20)150:

这个题花了我快 2个小时。。。

20:(6. N 字形变换)题目描述:

将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。
比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:
P   A   H   N
A P L S I I G
Y   I   R
之后,你的输出需要从左往右逐行读取,产生出一个新的字符串,比如:"PAHNAPLSIIGYIR"。
示例 2:
输入:s = "PAYPALISHIRING", numRows = 4
输出:"PINALSIGYAHRPI"
解释:
P     I    N
A   L S  I G
Y A   H R
P     I

第一版(就写了一版,我看解题也是模拟好像,就是模拟找规律的题)

class Solution {
   
    public String convert(String s, int numRows) {
   
        int len=s.length();
        if(len==1||numRows==1||len<=numRows){
   
            return s;
        }
        StringBuilder sb=new StringBuilder();
        int index=0;
        int count=(numRows-1)*2;
        // 第一行 直接算间隔 就可以
        int num=len%count==0?len/count:(len/count)+1;
        for(int i=0;i<num;i++)
        {
   
            sb.append(s.charAt(index));
            index+=count;
        }
        // 中间需要特殊处理 也是有规律的
        //,但是需要每次重置起始位置
        index=0;
        for(int i=1;i<numRows-1;i++){
   
            int inCount=(numRows-i-1)*2;
            int inIndex=i;
            while(inIndex<len){
   
                int temp=inIndex+count;
                for(int j=0;j<2;j++){
   
                    if(inIndex>=len){
   
                        break;
                    }
                    sb.append(s.charAt(inIndex));
                    inIndex+=inCount;
                }
                //重置起始位置
                inIndex=temp;
            }
        }
         // 最后一行 也是直接算间隔 就可以
        index=numRows-1;
        for(int i=0;i<num;i++){
   
            sb.append(s.charAt(index));
            if(index+count>=len){
   
                break;
            }
            index+=count;
        }
        return sb.toString();
    }
}

今天这个题搞得时间太长了。。只写了一道题,明天加油!!
早日跳槽!!!这道题对我来说真的不容易,可以说汗流浃背。。

相关推荐

  1. 面试经典150(20)

    2023-12-15 13:06:03       43 阅读
  2. 面试经典150(21-26)

    2023-12-15 13:06:03       41 阅读
  3. 面试经典150(27-28)

    2023-12-15 13:06:03       34 阅读
  4. LeetCode 面试经典150 27.移除元素

    2023-12-15 13:06:03       21 阅读
  5. 【leetcode面试经典15026.判断子序列(C++)

    2023-12-15 13:06:03       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-15 13:06:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-15 13:06:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-15 13:06:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-15 13:06:03       20 阅读

热门阅读

  1. QString的isNull与isEmpty

    2023-12-15 13:06:03       38 阅读
  2. Vue学习笔记-Vue3中的toRaw和markRaw

    2023-12-15 13:06:03       35 阅读
  3. 【贪心】LeetCode-55. 跳跃游戏

    2023-12-15 13:06:03       39 阅读
  4. C语言利用strcmp写简单数组存储的登录+注册程序

    2023-12-15 13:06:03       34 阅读
  5. 升级Xcode15,iOS17后问题解决

    2023-12-15 13:06:03       56 阅读
  6. PHP日期 函数

    2023-12-15 13:06:03       41 阅读
  7. vivado约束方法4

    2023-12-15 13:06:03       46 阅读
  8. SQL Server查询表结构

    2023-12-15 13:06:03       31 阅读