1361 · 文字并排

用「快刷四部曲」把 1361 题(文字并排,68 号原题复刻版)5 分钟速刷掉。

核心模板:贪心装行 → 算空槽 → 算平均/余量 → 最后一行左对齐


① 抽象模型

  • 每行尽可能多装单词,单词间至少 1 个空格。
  • 非末行:总空格 totalSpaces = maxWidth - sum(len(words)),空槽 gaps = wordCount-1
    平均 base = totalSpaces / gaps,余量 extra = totalSpaces % gaps,前 extra 个空槽多塞 1 个空格。
  • 末行:左对齐,单词间单空格,右侧统一补空格到 maxWidth。
  • 单行即末行处理。

② 最优算法

时间 O(N·L)(N 单词数,L 平均长度),空间 O(1) 除输出外。

算法:

  1. 双指针 i,j 找一行能装下的最右单词。
  2. 计算该行单词总长度 sumLen,空格总数 spaces = maxWidth - sumLen。
  3. 若 j 到末尾 或 该行仅 1 个单词 → 末行格式。
  4. 否则按 base + (idx < extra ? 1 : 0) 分配空格。
  5. StringBuilder 拼行,加入结果列表。

③ 边界/异常

  • words == null || words.length == 0 ⇒ 返回空列表。
  • maxWidth < 最短单词长度 ⇒ 题目保证合法,无需处理。

④ 代码(Java,可直接粘 LintCode)

java 复制代码
public List<String> fullJustify(String[] words, int maxWidth) {
    List<String> ans = new ArrayList<>();
    int n = words.length, i = 0;
    while (i < n) {
        int j = i, len = 0;
        // 1. 贪心装一行
        while (j < n && len + words[j].length() + (j - i) <= maxWidth) {
            len += words[j++].length();
        }
        int gaps = j - i - 1;                // 空槽数
        int spaces = maxWidth - len;         // 总空格
        StringBuilder line = new StringBuilder();
        // 2. 末行 or 单行
        if (j == n || gaps == 0) {
            for (int k = i; k < j; k++) {
                line.append(words[k]);
                if (k + 1 < j) line.append(' ');
            }
            while (line.length() < maxWidth) line.append(' ');
        } else {
            // 3. 均匀分空格
            int base = spaces / gaps, extra = spaces % gaps;
            for (int k = i; k < j; k++) {
                line.append(words[k]);
                if (k + 1 < j) {
                    for (int x = 0; x < base; x++) line.append(' ');
                    if (extra-- > 0) line.append(' ');
                }
            }
        }
        ans.add(line.toString());
        i = j;
    }
    return ans;
}

复杂度:

时间 O(N·L),空间 O(1) 除输出。

写完,Submit,一遍 AC。

相关推荐
颜酱1 小时前
二叉树遍历思维实战
javascript·后端·算法
宝贝儿好1 小时前
第二章: 图像处理基本操作
算法
小陈phd1 小时前
多模态大模型学习笔记(二)——机器学习十大经典算法:一张表看懂分类 / 回归 / 聚类 / 降维
学习·算法·机器学习
@––––––1 小时前
力扣hot100—系列4-贪心算法
算法·leetcode·贪心算法
CoovallyAIHub1 小时前
让本地知识引导AI追踪社区变迁,让AI真正理解社会现象
深度学习·算法·计算机视觉
CoderCodingNo1 小时前
【GESP】C++ 二级真题解析,[2025年12月]第一题环保能量球
开发语言·c++·算法
yumgpkpm1 小时前
预测:2026年大数据软件+AI大模型的发展趋势
大数据·人工智能·算法·zookeeper·kafka·开源·cloudera
CoovallyAIHub2 小时前
AAAI 2026这篇杰出论文说了什么?用LLM给CLIP换了个“聪明大脑”
深度学习·算法·计算机视觉
Physicist in Geophy.2 小时前
一维波动方程(从变分法角度)
线性代数·算法·机器学习
im_AMBER2 小时前
Leetcode 115 分割链表 | 随机链表的复制
数据结构·学习·算法·leetcode