当前位置: 首页 > news >正文

leetCode68. 文本左右对齐

基本思路:
leetCode68. 文本左右对齐
在这里插入图片描述


代码

class Solution {
public:vector<string> fullJustify(vector<string>& words, int maxWidth) {vector<string> res;for(int i = 0; i < words.size(); i++){ // 枚举有多少个单词int j = i + 1; // j表示各单词的下标int len = words[i].size(); // 该单词的长度// 看当前行可以放多少个单词// 当前单词长度 + 1个空格 + 下一个单词的长度 <= maxwidth,表示改行还可以继续放while(j < words.size() && len + 1 + words[j].size() <= maxWidth){len += 1 + words[j++].size();}string line = "";if(j == words.size() || j == i + 1){// 当j是在最后的位置,或者当前行只有一个单词,进行左对齐line += words[i];for(int k = i + 1; k < j; k++){line += ' ' + words[k];}while(line.size() < maxWidth) line += ' ';}else{ // 进行的是左右对齐int cnt = j - i - 1; //空隙的数量 = 单词的数量(j - i)- 1int r = maxWidth - len + cnt; // 总共的空格数量line += words[i];int k = 0;// 表示从第一个空隙开始计算while(k < r % cnt) { // 除不尽,r%cnt !=0,则前r%cnt个间隙r/cnt+1个空格,最后一个间隙r/cnt个空格line += string(r / cnt + 1, ' ') + words[i + k + 1];k++;}while(k < cnt) {// 这里加while是因为如果能整除,r%cnt=0,则全部为r/cnt个空格,对于每个cnt间隙内line += string(r / cnt, ' ') + words[i + k + 1];k++;}}res.push_back(line);i = j - 1;}return res;}
};
http://www.lryc.cn/news/343847.html

相关文章:

  • 搜狗输入法 PC端 v14.4.0.9307 去广告绿化版.
  • 【汇总】虚拟机网络不通(Xshell无法连接虚拟机)排查方法
  • C++开发基础之函数参数传递的几种类型
  • 使用memcache 和 redis 、 实现session 会话复制和保持
  • Tomcat 优化
  • 如何将pdf文件换成3d模型?---模大狮模型网
  • Docker 中快速构建 Redis Cluster 集群
  • C语言----杨辉三角
  • FlaUI
  • MySQL调优-01反范式化表设计
  • 74从零开始学Java之排序算法中的冒泡和选择排序
  • 【Qt问题】VS2019 Qt win32项目如何添加x64编译方式
  • LabVIEW换智能仿真三相电能表研制
  • Python | Leetcode Python题解之第69题x的平方根
  • libhv http client vs cpr
  • CTFHub-Web-文件上传
  • 笔记2:cifar10数据集获取及pytorch批量处理
  • FSD自动驾驶泛谈
  • golang获取变量动态类型
  • 外企接受大龄程序员吗?
  • 【DevOps】掌控云端:Google Cloud SDK 快速上手
  • 【Unity 踩坑系列】配置VScode环境Downloading the.NET Runtime Failed to download.NET 7.0.9installation timed out
  • 深入了解 NumPy:深度学习中的数学运算利器
  • 鸿蒙开发接口Ability框架:【@ohos.ability.particleAbility (particleAbility模块)】
  • Flutter笔记:Widgets Easier组件库(8)使用图片
  • 商务分析方法与工具(五):Python的趣味快捷-文件和文件夹操作自动化
  • codeforce#938 (div3) 题解
  • 【Docker】如何注册Hub账号并上传镜像到Hub仓库
  • [初阶数据结构】单链表
  • 项目使用git开发流程