博客
关于我
【Lintcode】524. Left Pad
阅读量:195 次
发布时间:2019-02-28

本文共 1222 字,大约阅读时间需要 4 分钟。

实现leftPad函数,包含两个版本:三个参数和两个参数。函数的目的是将给定字符串左边填充特定字符,使其长度达到指定大小。如果原字符串长度大于或等于目标大小或为空,则返回原字符串。

三个参数版本的函数

public static String leftPad(String originalStr, int size) {    if (originalStr == null || originalStr.isEmpty() || originalStr.length() >= size) {        return originalStr;    }    StringBuilder sb = new StringBuilder();    int padCount = size - originalStr.length();    if (padCount > 0) {        sb.append(String.valueOf(' ').repeat(padCount));    }    return sb.append(originalStr).toString();}

两个参数版本的函数

public static String leftPad(String originalStr, int size, char padChar) {    if (originalStr == null || originalStr.isEmpty() || originalStr.length() >= size) {        return originalStr;    }    StringBuilder sb = new StringBuilder();    int padCount = size - originalStr.length();    if (padCount > 0) {        sb.append(String.valueOf(padChar).repeat(padCount));    }    return sb.append(originalStr).toString();}

优化说明

  • 减少循环次数:使用String.valueOf(char).repeat(int)方法一次性生成所需的填充字符,避免了循环操作,提升效率。
  • 处理特殊情况:检查size是否为负数,避免出现负数循环次数,直接返回原字符串。
  • 空字符串处理:当originalStr为空时,直接返回空字符串,符合预期的行为。
  • 简洁代码结构:通过提取公共逻辑,减少代码重复,提高可读性。
  • 时间复杂度分析

    • 三个参数版本:O(size) 时间复杂度,因为最多执行size次循环。
    • 两个参数版本:O(size) 时间复杂度,同样最多执行size次循环。

    通过这种实现,确保了函数在不同情况下的正确性和高效性。

    转载地址:http://fqds.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现FFT算法(附完整源码)
    查看>>
    Objective-C实现fibonacci search斐波那契查找算法(附完整源码)
    查看>>
    Objective-C实现fibonacci斐波那契算法(附完整源码)
    查看>>
    Objective-C实现fibonacci斐波那契算法(附完整源码)
    查看>>
    Objective-C实现FIFO(附完整源码)
    查看>>
    Objective-C实现FigurateNumber垛积数算法(附完整源码)
    查看>>
    Objective-C实现finding bridges寻找桥梁算法(附完整源码)
    查看>>
    Objective-C实现first come first served先到先得算法(附完整源码)
    查看>>
    Objective-C实现FIR滤波器(附完整源码)
    查看>>
    Objective-C实现fischer yates shuffle洗牌算法(附完整源码)
    查看>>
    Objective-C实现fisherYates洗牌算法(附完整源码)
    查看>>
    Objective-C实现Floyd-Warshall算法(附完整源码)
    查看>>
    Objective-C实现FPmax算法(附完整源码)
    查看>>
    Objective-C实现frequency finder频率探测器算法(附完整源码)
    查看>>
    Objective-C实现FTP文件上传(附完整源码)
    查看>>
    Objective-C实现fuzzy operations模糊运算算法(附完整源码)
    查看>>
    Objective-C实现Gale-Shapley盖尔-沙普利算法(附完整源码)
    查看>>
    Objective-C实现gamma recursive伽玛递归算法(附完整源码)
    查看>>
    Objective-C实现gamma 伽玛功能算法(附完整源码)
    查看>>
    Objective-C实现gauss easte高斯复活节日期算法(附完整源码)
    查看>>