leetcode 68. 文本左右对齐-java实现
题目所属分类
双指针
原题链接
给定一个单词数组 words 和一个长度 maxWidth ,重新排版单词,使其成为每行恰好有 maxWidth 个字符,且左右两端对齐的文本。
你应该使用 “贪心算法” 来放置给定的单词;也就是说,尽可能多地往每行中放置单词。必要时可用空格 ’ ’ 填充,使得每行恰好有 maxWidth 个字符。
要求尽可能均匀分配单词间的空格数量。如果某一行单词间的空格不能均匀分配,则左侧放置的空格数要多于右侧的空格数。
文本的最后一行应为左对齐,且单词之间不插入额外的空格。
代码案例:
题解
细节注意蛮多的
class Solution {
public List<String> fullJustify(String[] words, int maxWidth) {
List<String> res = new ArrayList<>();
for(int i = 0 ; i < words.length ; i++){
//j从下一个单词开始看
int j = i + 1 ;
int len = words[i].length() ;
while(j < words.length && len + 1 + words[j].length() <= maxWidth )
len += 1 + words[j++].length();
//三种情况:最后一行或只有一行只有一个 j此时已经遍历到一行的最后了
String line = "";//定义当前行
if(j == words.length || j == i + 1 ){
line += words[i] ;
for(int k = i + 1 ; k < j ; k++) line += " " + words[k] ;
while(line.length() < maxWidth) line += " ";
}else{
int cnt = j - i - 1 ;//空隙个数
int r = maxWidth - len + cnt ;//当前行的总空格数
line += words[i];
//分配空格
int a = r/cnt ;//基本份
int b = r % cnt ;//多余份
for(int k = i + 1 ; k < j ; k ++){
//每次加一
if(b-- > 0) line += get(a + 1) + words[k] ;
else line += get(a) + words[k];
}
}
res.add(line);
i = j - 1 ;//更新i
}
return res ;
}
public String get(int x ){//字符串中形成x个空格
String ans = "";
for(int i = 0; i < x ; i ++){
ans += " ";
}
return ans ;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理