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;
    }
}
相关推荐
Lee川1 小时前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试
Lee川5 小时前
从异步迷雾到优雅流程:JavaScript异步编程与内存管理的现代化之旅
javascript·面试
晴殇i6 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
绝无仅有7 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
绝无仅有7 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
AAA梅狸猫8 小时前
Looper.loop() 循环机制
面试
AAA梅狸猫8 小时前
Handler基本概念
面试
Wect9 小时前
浏览器缓存机制
前端·面试·浏览器
掘金安东尼9 小时前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试
掘金安东尼9 小时前
Next.js 企业级落地
前端·javascript·面试