力扣面试150 文本左右对齐 贪心 字符串 满注释版

Problem: 68. 文本左右对齐

思路

👩‍🏫 三叶题解

💖 Code

Java 复制代码
class Solution {
public List<String> fullJustify(String[] words, int maxWidth)
	{
		List<String> ans = new ArrayList<>();// 结果
		List<String> list = new ArrayList<>();// 存当前行可容纳的单词

		int n = words.length;
		for (int i = 0; i < n;)
		{
			list.clear();// 清空上一行的单词
			list.add(words[i]);// 题目保证每个单词的长度 <= maxWidth,所以每行肯定可以放一个单词
			int lineLen = words[i++].length(); // 当前行的长度:单词 + 空格
			while (i < n && lineLen + 1 + words[i].length() <= maxWidth)// 判断是否可以放多一个单词
			{
				lineLen += 1 + words[i].length();// 加上单词间的空格
				list.add(words[i++]);
			}
//			当前行是最后一行,特殊处理为 左对齐
			if (i == n)
			{
				StringBuffer sb = new StringBuffer(list.get(0));
				for (int j = 1; j < list.size(); j++)// 两两单词间加一个空格拼接起来
					sb.append(" ").append(list.get(j));
				while (sb.length() < maxWidth)// 用空格补全长度
					sb.append(" ");
				ans.add(sb.toString());
				break;
			}

//			当前行只有一个空格,左对齐 右边空格补全
			int wordCnt = list.size();
			if (wordCnt == 1)
			{
				String str = list.get(0);
				while (str.length() != maxWidth)
					str += " ";
				ans.add(str);
				continue;
			}
//			一般情况
			// 所有单词的总长度 = 行长度 - 单词间空格数量(wordCnt - 1)*1
			int wordWidth = lineLen - (wordCnt - 1);
			// 当前行空格总长度 = 最大长度 - 单词长度
			int spaceWidth = maxWidth - wordWidth;
			// 单词间的平均空格数量(向下取整)
			int spaceItemWidth = spaceWidth / (wordCnt - 1);
			String spaceItem = "";
			for (int j = 0; j < spaceItemWidth; j++)
				spaceItem += " ";
			StringBuilder sb = new StringBuilder();
//			j 枚举每个单词的下标;sum 记录当前空格的总数
			for (int j = 0, sum = 0; j < wordCnt; j++)// 遍历当前行的每一个单词
			{
				String word = list.get(j);
				sb.append(word);
				if (j == wordCnt - 1)
					break;// 最后一个单词不要加入 空格分割
				sb.append(spaceItem);// 处理第一个单词时就把间隙要填的空格补上了
				sum += spaceItemWidth;
//				剩余可填入的间隙数(两个单词间的间隙:即还剩多少个 spaceItem 要填)
//				wordCnt-1:wordCnt 个单词有(wordCnt-1)个单词间隙 
				int remain = wordCnt - 1 - (j + 1);// (j+1) 下标偏移
//				剩余间隙 * 间隙长度 + 当前总空格长度  <  空格总长度
				if (remain * spaceItemWidth + sum < spaceWidth)
				{
					sb.append(" ");// 当前间隙补多一个空格
					sum++;
				}
			}
			ans.add(sb.toString());
		}

		return ans;
	}
}
相关推荐
大胆飞猪24 分钟前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
Kisorge2 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
铭哥的编程日记3 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区3 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展
cici158743 小时前
基于高光谱成像和偏最小二乘法(PLS)的苹果糖度检测MATLAB实现
算法·matlab·最小二乘法
StarPrayers.5 小时前
自蒸馏学习方法
人工智能·算法·学习方法
大锦终5 小时前
【动规】背包问题
c++·算法·动态规划
智者知已应修善业5 小时前
【c语言蓝桥杯计算卡片题】2023-2-12
c语言·c++·经验分享·笔记·算法·蓝桥杯
hansang_IR6 小时前
【题解】洛谷 P2330 [SCOI2005] 繁忙的都市 [生成树]
c++·算法·最小生成树
Croa-vo6 小时前
PayPal OA 全流程复盘|题型体验 + 成绩反馈 + 通关经验
数据结构·经验分享·算法·面试·职场和发展