leetcode 68. 文本左右对齐-java实现

题目所属分类

双指针

原题链接

给定一个单词数组 words 和一个长度 maxWidth ,重新排版单词,使其成为每行恰好有 maxWidth 个字符,且左右两端对齐的文本。

你应该使用 “贪心算法” 来放置给定的单词;也就是说,尽可能多地往每行中放置单词。必要时可用空格 ’ ’ 填充,使得每行恰好有 maxWidth 个字符。

要求尽可能均匀分配单词间的空格数量。如果某一行单词间的空格不能均匀分配,则左侧放置的空格数要多于右侧的空格数。

文本的最后一行应为左对齐,且单词之间不插入额外的空格。

代码案例:在这里插入图片描述

题解

在这里插入图片描述
在这里插入图片描述

细节注意蛮多的

class Solution {
    public List<String> fullJustify(String[] words, int maxWidth) {
        List<String> res = new ArrayList<>();
        for(int i = 0 ; i < words.length ; i++){
            //j从下一个单词开始看
            int j = i + 1 ;
            int len = words[i].length() ;
            while(j < words.length && len + 1 + words[j].length() <= maxWidth ) 
            len += 1 + words[j++].length();
            //三种情况:最后一行或只有一行只有一个 j此时已经遍历到一行的最后了
            String line = "";//定义当前行
            if(j == words.length || j ==  i + 1 ){
                line += words[i] ;
                for(int k = i + 1 ; k < j ; k++) line += " " + words[k] ;
                while(line.length() < maxWidth) line += " ";
            }else{
                int cnt = j - i - 1 ;//空隙个数
                int r = maxWidth - len + cnt ;//当前行的总空格数
                line += words[i];
                //分配空格
                int a = r/cnt ;//基本份
                int b = r % cnt ;//多余份
                for(int k = i + 1 ; k < j ; k ++){
                    //每次加一
                    if(b-- > 0) line += get(a + 1) + words[k] ;
                    else line += get(a) + words[k];
                }

            }
            res.add(line);
            i = j - 1 ;//更新i  
        }
        return res ;
    }
    public String get(int x ){//字符串中形成x个空格
        String ans = "";
        for(int i = 0; i < x ; i ++){
                ans += " ";
        }
        return ans ;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

依嘫_吃代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值