文本左右对齐

hello 大家好!今天开写一个新章节,每一天一道算法题。让我们一起来学习算法思维吧!

javascript 复制代码
function fullJustify(words, maxWidth) {
    // 用于存储最终排版好的每一行文本
    const result = [];
    // 用于遍历单词数组的索引,初始化为 0
    let i = 0;

    // 开始遍历单词数组,直到所有单词都被处理完
    while (i < words.length) {
        // 用于存储当前行要放置的单词
        let lineWords = [];
        // 当前行已使用的字符长度(仅包含单词长度,不包含单词间的空格),初始化为 0
        let currentLength = 0;

        // 尽可能多地往当前行添加单词
        // 条件判断:i 小于单词数组长度,并且当前行添加新单词和对应空格后的总长度不超过 maxWidth
        while (i < words.length && currentLength + words[i].length + lineWords.length <= maxWidth) {
            // 将当前单词添加到当前行的单词列表中
            lineWords.push(words[i]);
            // 更新当前行已使用的字符长度,加上新添加单词的长度
            currentLength += words[i].length;
            // 移动到下一个单词
            i++;
        }

        // 计算当前行还需要添加多少个空格才能达到 maxWidth 的长度
        let spacesToAdd = maxWidth - currentLength;
        // 用于存储当前行最终排版好的文本
        let line = '';

        // 判断是否为最后一行或者当前行只有一个单词
        if (i === words.length || lineWords.length === 1) {
            // 如果是最后一行或者只有一个单词,采用左对齐的方式
            // 将当前行的单词用单个空格连接起来
            line = lineWords.join(' ');
            // 在连接好的单词后面添加剩余所需的空格,使整行长度达到 maxWidth
            line += ' '.repeat(maxWidth - line.length);
        } else {
            // 计算平均每个单词间隔需要添加的空格数
            let spacesBetweenWords = Math.floor(spacesToAdd / (lineWords.length - 1));
            // 计算平均分配后剩余的额外空格数,这些额外空格要优先放在左侧的间隔中
            let extraSpaces = spacesToAdd % (lineWords.length - 1);

            // 遍历当前行的每个单词
            for (let j = 0; j < lineWords.length; j++) {
                // 将当前单词添加到当前行的文本中
                line += lineWords[j];
                // 如果不是最后一个单词,需要添加单词间的空格
                if (j < lineWords.length - 1) {
                    // 先添加平均分配的空格数
                    // 再判断是否还有额外空格,如果有且当前是前面的间隔(j < extraSpaces),则多添加一个空格
                    line += ' '.repeat(spacesBetweenWords + (j < extraSpaces? 1 : 0));
                }
            }
        }

        // 将当前行排版好的文本添加到最终结果数组中
        result.push(line);
    }

    // 返回最终排版好的文本数组
    return result;
}

// 测试示例
const words = ["This", "is", "an", "example", "of", "text", "justification."];
const maxWidth = 16;
console.log(fullJustify(words, maxWidth));

代码思路总结

这段代码的核心思路是使用贪心算法来处理单词排版问题。首先,尝试在每一行中尽可能多地添加单词,直到无法再添加而不超过 maxWidth 限制。然后,根据当前行是否为最后一行或者是否只有一个单词,采用不同的排版方式:

  • 最后一行或只有一个单词:左对齐,单词间用单个空格连接,剩余长度用空格填充在末尾。
  • 其他行:计算平均每个单词间隔应有的空格数以及剩余的额外空格数,优先将额外空格分配到左侧的间隔中,以保证左侧的空格数多于右侧。
相关推荐
zhojiew26 分钟前
service mesh的定制化与性能考量
java·云原生·service_mesh
cdut_suye33 分钟前
【Linux系统】从零开始构建简易 Shell:从输入处理到命令执行的深度剖析
java·linux·服务器·数据结构·c++·人工智能·python
-qOVOp-35 分钟前
zst-2001 历年真题 设计模式
java·算法·设计模式
yaoshengvalve1 小时前
V型球阀材质性能深度解析:专攻颗粒、料浆与高腐蚀介质的工业利器-耀圣
开发语言·网络·数据结构·c++·安全·材质
evolution_language1 小时前
LintCode第68题-二叉树的前序遍历,第67题-二叉树的后序遍历
数据结构·算法·新手必刷编程50题
张狂年少1 小时前
【十五】Mybatis动态SQL实现原理
java·sql·mybatis
passionSnail1 小时前
《用MATLAB玩转游戏开发:从零开始打造你的数字乐园》基础篇(2D图形交互)-俄罗斯方块:用旋转矩阵打造经典
算法·matlab·矩阵·游戏程序·交互
yxc_inspire1 小时前
C++STL在算法竞赛中的应用详解
c++·算法·stl
James. 常德 student1 小时前
leetcode-hot-100(哈希)
算法·leetcode·哈希算法
元亓亓亓1 小时前
Java后端开发day46--多线程(二)
java·开发语言