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 ;
    }
}
posted @   依嘫  阅读(25)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示