[leetcode] 68. 文本左右对齐

文章目录

  • 题目描述
  • 解题方法
    • 贪心
      • java代码
      • 复杂度分析

题目描述

给定一个单词数组 words 和一个长度 maxWidth ,重新排版单词,使其成为每行恰好有 maxWidth 个字符,且左右两端对齐的文本。

你应该使用 “贪心算法” 来放置给定的单词;也就是说,尽可能多地往每行中放置单词。必要时可用空格 ' ' 填充,使得每行恰好有 maxWidth 个字符。

要求尽可能均匀分配单词间的空格数量。如果某一行单词间的空格不能均匀分配,则左侧放置的空格数要多于右侧的空格数。

文本的最后一行应为左对齐,且单词之间不插入额外的空格。

注意:

  • 单词是指由非空格字符组成的字符序列。
  • 每个单词的长度大于 0,小于等于 maxWidth
  • 输入单词数组 words 至少包含一个单词。

示例 1:

输入: words = ["This", "is", "an", "example", "of", "text", "justification."], maxWidth = 16
输出:
["This    is    an","example  of text","justification.  "
]

示例 2:

输入:words = ["What","must","be","acknowledgment","shall","be"], maxWidth = 16
输出:
["What   must   be","acknowledgment  ","shall be        "
]
解释: 注意最后一行的格式应为 "shall be    " 而不是 "shall     be",因为最后一行应为左对齐,而不是左右两端对齐。       第二行同样为左对齐,这是因为这行只包含一个单词。

示例 3:

输入:words = ["Science","is","what","we","understand","well","enough","to","explain","to","a","computer.","Art","is","everything","else","we","do"],maxWidth = 20
输出:
["Science  is  what we","understand      well","enough to explain to","a  computer.  Art is","everything  else  we","do                  "
]

提示:

  • 1 <= words.length <= 300
  • 1 <= words[i].length <= 20
  • words[i] 由小写英文字母和符号组成
  • 1 <= maxWidth <= 100
  • words[i].length <= maxWidth

解题方法

贪心

思路就是按照上面的规则来个每一行放置单词。

我们可以总结出以下几种情况。

  1. 除最后一行外,每一行的单词有两种情况。
  • 当该行单词数 > 1时,需要给单词之间加空格,最后一个单词刚好放到末尾,后面无空格。
  • 当该行单词数 = 1时,只需要给该单词后面加空格。
  1. 如果是最后一行,除最后一个单词外,需要给每个单词后面加一个空格。最后一个单词后面补充剩余的空格。

总结出以上情况后,那我们就可以构建思路了。

我们可以记录几个变量curWidth代表当前行的单词长度curNums代表当前行的单词个数words[i]代表下一个要添加的单词。当curWidth + words[i].length() + curNums <= maxWidth时,当前行就可以加入新单词;否则,将当前行组成的字符串加入结果集。curWidthcurNums重置为0

接下来就是怎么添加单词后面的空格了。我们可以计算当前行可以添加的空格数量,然后根据上面总结的情况将空格合理分配到单词后面。这块可以看代码实现,我已将部分重要的注释加入到代码中。

java代码

public List<String> fullJustify(String[] words, int maxWidth) {List<String> list = new ArrayList<>();int i = 0;// 记录当前行的单词长度int curWidth = 0;// 记录当前行的单词个数int curNums = 0;while (i < words.length) {// 当前行单词长度 + 下一个单词长度 + 当前行的单词数量(最少空格数量) < 最大宽度,说明可以把下一个单词加入当前行if (curWidth + words[i].length() + curNums <= maxWidth) {curWidth += words[i].length();curNums++;i++;} else {// 空格个数int spaces = maxWidth - curWidth;int a = 0;int b = 0;// 当前行单词数 > 1 时if (curNums - 1 != 0) {// 除当前行的最后一个单词外,每个单词后面至少加a个空格,前b个单词后面还需要再加1个空格a = spaces / (curNums - 1);b = spaces % (curNums - 1);}StringBuilder lineBuilder = new StringBuilder();for (int j = 0; j < curNums - 1; j++) {// 加单词lineBuilder.append(words[i - curNums + j]);// 加空格for (int k = 0; k < a; k++) {lineBuilder.append(' ');}if (b-- > 0) {lineBuilder.append(' ');}}// 加当前行的最后一个单词lineBuilder.append(words[i - 1]);// 如果该行只有一个单词,需要在单词后面的剩余空间加上空格if (curNums == 1) {while (spaces-- > 0) {lineBuilder.append(' ');}}// 当前行加入结果集list.add(lineBuilder.toString());// 当前行加入结果集后,当前行宽度和当前行单词个数重置为0curWidth = 0;curNums = 0;}}StringBuilder lineBuilder = new StringBuilder();// 最后一行结果集先加单词,再加1个空格for (int j = 0; j < curNums - 1; j++) {lineBuilder.append(words[i - curNums + j]);lineBuilder.append(' ');}// 剩余空格个数int spaces = maxWidth - curWidth - (curNums - 1);lineBuilder.append(words[i - 1]);// 最后一个单词后面把剩余空格都加上while (spaces-- > 0) {lineBuilder.append(' ');}// 最后一行加入结果集list.add(lineBuilder.toString());return list;
}

复杂度分析

时间复杂度: O ( m ) O(m) O(m) m m m是单词长度总和 + 空格总和。
空间复杂度: O ( m ) O(m) O(m),结果需要提供 O ( m ) O(m) O(m)的存储空间。


  • 个人公众号
    个人公众号
  • 个人小游戏
    个人小游戏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/689281.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第五十八节 Java设计模式 - 适配器模式

Java设计模式 - 适配器模式 我们在现实生活中使用适配器很多。例如&#xff0c;我们使用存储卡适配器连接存储卡和计算机&#xff0c;因为计算机仅支持一种类型的存储卡&#xff0c;并且我们的卡与计算机不兼容。 适配器是两个不兼容实体之间的转换器。适配器模式是一种结构模…

Linux进程——进程地址空间

前言&#xff1a;在讲完环境变量后&#xff0c;相信大家对Linux有更进一步的认识&#xff0c;而Linux进程概念到这也快接近尾声了&#xff0c;现在我们了解Linux进程中的地址空间&#xff01; 本篇主要内容&#xff1a; 了解程序地址空间 理解进程地址空间 探究页表和虚拟地址空…

具备教学意义的实操(用队列实现栈)

225. 用队列实现栈 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/implement-stack-using-queues/description/ 实现逻辑 一个是先进先出&#xff08;队列&#xff09;&#xff0c;一个是后进先出&#xff08;栈&#xff09; 这里用两个队列导入一下数据…

实体同城商家短视频获客,3天直播课,玩转实体商家私域,引爆门店增长

课程内容&#xff1a; 实体同城3天直播课【资料】 实体商家获客第一天 .mp4 实体商家获客第二天上.mp4 实体商家获客第二天,mp4 实体商家获客第三天.mp4 实体商家获客第4天.mp4 网盘自动获取 链接&#xff1a;https://pan.baidu.com/s/1lpzKPim76qettahxvxtjaQ?pwd0b8x…

什么是翘尾因素

在有关CPI 的分析文章和新闻稿件中&#xff0c;经常会出现“翘尾因素”或“翘尾影响” 等词汇&#xff0c;这是分析同比价格指数变动幅度时所特有的概念。那么什么是“翘尾因素” 或“翘尾影响”呢&#xff1f; 一、什么是翘尾因素 “翘尾因素”是指上年价格上涨&#xff08;…

瀚高数据库(HighGoDB)Windows安装使用

1.下载 2.安装 瀚高数据库下载与安装&#xff08;Windows版&#xff09;-CSDN博客 3.连接工具 4.建库、建表操作 瀚高数据库管理工具-CSDN博客 *报错Cant access non-default database&#xff0c;需要右键数据库-设为活动对象 5.导入外部数据&#xff08;迁移、对比&…

栈实现队列

一、分析 栈的特点是先出再入&#xff0c;而队列的特点为先入先出&#xff0c;所以我们创造两个栈&#xff0c;一个用来存放数据&#xff0c;一个用来实现其它功能此时栈顶为队尾&#xff1b;当要找队头数据时将前n-1个数据移入到另一个栈中&#xff0c;此时剩余那个数据为队头…

新时代背景下的班子建设挑战与对策

一、引言 随着新时代的到来&#xff0c;社会、经济和科技的飞速发展给组织班子建设带来了前所未有的挑战。如何在这一背景下建设一支高效、协作、创新的领导班子&#xff0c;已成为组织发展的核心议题。本文将从挑战与对策两个维度&#xff0c;深入剖析新时代背景下的班子建设…

Coursera吴恩达深度学习专项课程01: Neural Networks and Deep Learning 学习笔记 Week 02

Week 02 of Neural Networks and Deep Learning Course Certificate 本文是学习 https://www.coursera.org/learn/neural-networks-deep-learning 这门课的笔记 Course Intro 文章目录 Week 02 of Neural Networks and Deep LearningLearning Objectives [1] Logistic Regres…

小程序地理位置接口申请教程来啦4步学会

小程序地理位置接口有什么功能&#xff1f; 如果我们提审后驳回理由写了“当前提审小程序代码包中地理位置相关接口( chooseAddress、getLocation )暂未开通&#xff0c;建议完成接口开通后或移除接口相关内容后再进行后续版本提审”&#xff0c;如果你也碰到类似问题&#xff…

汇昌联信科技:拼多多可以做无货源吗?

在探讨电商平台的经营模式时&#xff0c;"无货源"这一概念经常被提及。它指的是卖家在不需要事先囤积大量商品的情况下&#xff0c;通过与供应商的合作&#xff0c;直接将订单信息传递给他们&#xff0c;由供应商完成发货的过程。针对“拼多多可以做无货源吗?”这一…

028.实现 strStr()

题意 给你两个字符串 haystack 和 needle &#xff0c;请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标&#xff08;下标从 0 开始&#xff09;。如果 needle 不是 haystack 的一部分&#xff0c;则返回 -1 。 难度 简单 示例 例 1 输入&#xff1a;hays…