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。

相关推荐
中草药z21 分钟前
【嵌入模型】概念、应用与两大 AI 开源社区(Hugging Face / 魔塔)
人工智能·算法·机器学习·数据集·向量·嵌入模型
知乎的哥廷根数学学派43 分钟前
基于数据驱动的自适应正交小波基优化算法(Python)
开发语言·网络·人工智能·pytorch·python·深度学习·算法
ADI_OP1 小时前
ADAU1452的开发教程10:逻辑算法模块
算法·adi dsp中文资料·adi dsp·adi音频dsp·adi dsp开发教程·sigmadsp的开发详解
xingzhemengyou11 小时前
C语言 查找一个字符在字符串中第i次出现的位置
c语言·算法
小六子成长记3 小时前
【C++】:搜索二叉树的模拟实现
数据结构·c++·算法
汉克老师3 小时前
GESP2025年9月认证C++二级真题与解析(编程题1(优美的数字))
c++·算法·整除·枚举算法·求余·拆数
Zevalin爱灰灰4 小时前
现代控制理论——第二章 系统状态空间表达式的解
线性代数·算法·现代控制
菜鸟233号4 小时前
力扣377 组合总和 Ⅳ java实现
java·数据结构·算法·leetcode
我是大咖4 小时前
二级指针与指针数组搭配
c语言·数据结构·算法
葫三生5 小时前
三生原理范畴语法表明中国哲学可为算法母语
人工智能·深度学习·算法·transformer