day10(11.7)——leetcode面试经典150

68. 文本左右对齐​​​​​​

这道题好繁琐啊,我的思路是一个一个单词判断,每一个都加上两个单词之间的空格去看长度是否超过maxWidth,如果超过了,进行判断,只有一个单词或者到了最后一行,直接左对齐,后面填充空格,超过一个单词,进行计算每个单词之间的空格的个数,进行填充,一个一个累加,最后加入最终的结果列表。

但是真的一个不小心就容易写错......

68. 文本左右对齐

题目:

题解:

java 复制代码
class Solution {
    public List<String> fullJustify(String[] words, int maxWidth) {
        List<String> result = new ArrayList<>();
        int n = words.length;
        int i = 0;

        while (i < n) {
            // 1. 找出当前行能放哪些单词 [i, j)
            int j = i;
            int lineLength = 0; // 只算单词长度,不算空格

            while (j < n && lineLength + words[j].length() + (j - i) <= maxWidth) {
                lineLength += words[j].length();
                j++;
            }

            // 2. 处理这一行
            int wordCount = j - i;
            int spaces = maxWidth - lineLength; // 总共要填充的空格数

            StringBuilder line = new StringBuilder();

            if (j == n || wordCount == 1) {
                // 最后一行 或 只有一个单词:左对齐
                for (int k = i; k < j; k++) {
                    line.append(words[k]);
                    if (k < j - 1) line.append(" ");
                }
                // 末尾补空格
                while (line.length() < maxWidth) {
                    line.append(" ");
                }
            } else {
                // 中间行:两端对齐
                int avgSpaces = spaces / (wordCount - 1);
                int extraSpaces = spaces % (wordCount - 1);

                for (int k = i; k < j; k++) {
                    line.append(words[k]);
                    if (k < j - 1) {
                        // 添加基础空格
                        for (int s = 0; s < avgSpaces; s++) {
                            line.append(" ");
                        }
                        // 前 extraSpaces 个间隙多加一个空格
                        if (k - i < extraSpaces) {
                            line.append(" ");
                        }
                    }
                }
            }

            result.add(line.toString());
            i = j; // 移动到下一行
        }
        return result;
    }
}
相关推荐
better_liang4 小时前
每日Java面试场景题知识点之-消息队列MQ核心场景与实战
java·面试·kafka·消息队列·rabbitmq·rocketmq·mq
小江的记录本4 小时前
【JVM虚拟机】垃圾回收GC:四种引用类型:强引用、软引用、弱引用、虚引用(附《思维导图》+《面试高频考点清单》)
java·jvm·spring boot·后端·python·spring·面试
better_liang5 小时前
每日Java面试场景题知识点之-SpringBoot启动流程
java·面试·springboot·源码解析·启动流程
Raink老师5 小时前
【AI面试临阵磨枪-69】如何设计一个支持百万级工具的 Agent 系统?如何快速路由与选择工具?
人工智能·面试·职场和发展
Raink老师6 小时前
【AI面试临阵磨枪-77】音视频 + AI:实时字幕、翻译、降噪、虚拟人、多模态对话
人工智能·面试·音视频
Raink老师9 小时前
【AI面试临阵磨枪-76】社交 AI:内容生成、审核、智能回复、多模态理解、安全治理
人工智能·安全·面试
仙俊红9 小时前
Integer\int对比,equals()\hashcode面试
java·面试·职场和发展
kyriewen10 小时前
手写虚拟DOM后,我反问面试官:key为什么不能用index?
前端·react.js·面试
长谷深风11110 小时前
Java 面试高频:反射机制与异常体系全面解析
java·开发语言·面试·exception·java 反射·java 异常·class 对象
甜味弥漫10 小时前
深度解析 JS 中的 this 指向:从底层逻辑到实战规则
javascript·面试