博客
关于我
【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/

    你可能感兴趣的文章
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
    查看>>
    OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
    查看>>
    OpenPPL PPQ量化(4):计算图的切分和调度 源码剖析
    查看>>
    OpenPPL PPQ量化(5):执行引擎 源码剖析
    查看>>
    Openresty框架入门详解
    查看>>
    OpenResty(2):OpenResty开发环境搭建
    查看>>
    openshift搭建Istio企业级实战
    查看>>
    Openstack 之 网络设置静态IP地址
    查看>>
    OpenStack 网络服务Neutron详解
    查看>>
    Openstack(两控制节点+四计算节点)-1
    查看>>
    Openstack企业级云计算实战第二、三期培训即将开始
    查看>>
    OpenStack安装部署实战
    查看>>
    OpenStack的基本概念与架构详解
    查看>>
    Openstack的视频学习
    查看>>
    openstack虚拟机迁移live-migration中libvirt配置
    查看>>
    ORACEL学习--理解over()函数
    查看>>