LeetCode 刷题【68. 文本左右对齐】

68. 文本左右对齐

自己做

解:直接遍历划分情况

cpp 复制代码
class Solution {
public:
    vector<string> fullJustify(vector<string>& words, int maxWidth) {
        vector<string> res;
        string row;                           //当前行
        int row_len = 0;                      //当前行的单词长度

        int begin = 0;                        //begin,end标记一行起始
        int end = 0;

        while(end < (int)words.size()){
            row_len += words[end].size() + 1;

            if(row_len - 1 > maxWidth){               //超过一行限制,该行包含的单词:[begin,end) => 从words[begin]取到words[end - 1],注:这里必然不可能是尾行
                row_len -= (words[end].size() + 2);        //去除越界的部分:最后一个单词和两边的空格
                // cout << row_len << endl;
                int space_sum = maxWidth - row_len;        //要补充的空格总数
                int div_space = 0;
                int add_space = 0;

                if(end - begin - 1 != 0){
                    div_space = space_sum / (end - begin - 1);       //每个间隔的补充长度
                    add_space = space_sum % (end - begin - 1);       //额外补充间隔的长度             
                }

                // cout << begin << "," << end << "," << div_space << "," << add_space << endl;

                //一行
                for(int i = begin; i < end; i++){
                    row += words[i];                      //拼接单词
                    
                    //加空格
                    if(i != end - 1){
                        row += string(div_space + 1, ' ');   //每个间隔长度

                        if(add_space > 0){                   //如果有额外要补充的间隔,从左往右进行补充
                            row += ' ';
                            add_space--;
                        }
                    }
                }

                //一行只有一个单词的情况,往后补充空格
                if(begin == end - 1)
                    //尾部加空格
                    row += string(maxWidth - row_len, ' ');
                    
                //一行结束,调整begin起始位置,将该行加入结果
                res.push_back(row);
                begin = end;
                row = "";
                row_len = 0;

            }
            else if(row_len - 1 == maxWidth){     //刚好够一行,该行包含的单词:[begin,end] => 从words[begin]取到words[end]
                //一行
                for(int i = begin; i <= end; i++){
                    row += words[i];                      //拼接单词
                    
                    //加空格
                    if(i != end)
                        row += " ";                           //每个间隔长度为1
                }

                //一行结束,调整begin起始位置,将该行加入结果
                res.push_back(row);
                end++;
                begin = end;
                row = "";
                row_len = 0;

            }
            else{                           //对于没填充满的情况: row_len - 1 < 16
                if(end == (int)words.size() - 1){          //如果是尾行,后面补充空格
                    //一行
                    for(int i = begin; i <= end; i++){
                        row += words[i];                      //拼接单词
                        
                        //加空格
                        row += " ";                           //每个间隔长度为1
                    }

                    //尾部加空格
                    row += string(maxWidth - row_len, ' ');

                    //加入结果并结束循环
                    res.push_back(row);
                    break;                                      
                }
                else                                        //如果不是尾行,继续往后延伸
                    end++;

            }
        }

        return res;
    }
};
相关推荐
_清歌27 分钟前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局28 分钟前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象29 分钟前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局29 分钟前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局30 分钟前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局39 分钟前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法
To_OC12 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵15 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC18 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode