试着解下第一题:
1. 首字母对齐其实相当于 每行 word的数目一致(除最后一行以外),如楼主给的提示所示,要么每行1个,要么2个,要么 3个……
2. 每行最少 1个单词 (最长的那个word 占据了 k 个位置),最多 把所有单词都排下
3. 因此可以试着 2分每行word的数目 (1最小,所有单词数目最大),尝试查找 k 列能容纳下的最多的 word 个数
4. 假设 我们想 使得每行容纳 m 个单词,则从第一个单词开始,循环 m 次,求得m个单词能否装进 k 列 (需要注意除最后一个单词外,前 m -1 个单词后面要多加一个空格),判断m 装好了以后是否 <= k
5. 如果上述判断不成立,则m 太大,二分的 hi = mid; 如果上述 判断 true,则 m 略小,还可继续装下更多的单词,二分的 lo = mid
6. 找到最大 m 后,单词数目 / m + 1 即可