LeetCode-68-Text Justification 细节题

本文介绍了一种用于文本布局的算法,特别关注如何处理不同长度的单词以适应指定的最大宽度限制。该算法通过调整单词间的空格数量来实现均匀布局,并且能够处理包括单个单词在内的各种边界情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

很烦的边界条件,还能输入[""],2这种数据的???然后标准输出是["  "],真搞不懂意义何在

class Solution(object):
    def fullJustify(self, words, maxWidth):
        """
        :type words: List[str]
        :type maxWidth: int
        :rtype: List[str]
        """
        Len=len(words)
        if Len==0:return []
        ans=[]
        if Len==1:
            curans=""
            curans+=words[0]
            for i in range(maxWidth-len(words[0])):
                curans+=" "
            ans.append(curans)
            return ans
        
        curS=[words[0]]
        curC=len(words[0])
        for i in range(1,Len):
            if curC+1+len(words[i])<=maxWidth:
                curS.append(words[i])
                curC+=1+len(words[i])
                
            else:
                ans.append(self.modify(curS,maxWidth))
                curC=len(words[i])
                curS=[]
                curS.append(words[i])
            if i==Len-1:
                ans.append(self.modifyLast(curS,maxWidth))
        return ans
        
    def modify(self,s,l):
        Len=len(s)
        if Len==1:
            ans=""
            ans+=s[0]
            for i in range(l-len(s[0])):
                ans+=" "
            return ans
        gapNumber=Len-1
        ans=""
        totalLen=0
        for i in range(Len):
            totalLen+=len(s[i])
        totalSpace=l-totalLen
        MIN=totalSpace/gapNumber
        bigSpaceNumber=totalSpace-MIN*gapNumber
        smallSpaceNumber=gapNumber-bigSpaceNumber
        ans+=s[0]
        smallSpace=""
        for i in range(MIN):
            smallSpace+=" "
        bigSpace=smallSpace+" "
        cnt=1
        while(bigSpaceNumber>0):
            ans+=bigSpace
            ans+=s[cnt]
            cnt+=1
            bigSpaceNumber-=1
        while(smallSpaceNumber>0):
            ans+=smallSpace
            ans+=s[cnt]
            cnt+=1
            smallSpaceNumber-=1
        return ans
        
    def modifyLast(self,s,l):
        ans=s[0]
        for i in range(1,len(s)):
            ans+=" "+s[i]
        Len=len(ans)
        for i in range(l-Len):
            ans+=" "
        return ans
        
        


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值