806. 写字符串需要的行数(2022-4-12)
我们要把给定的字符串 S 从左到右写到每一行上,每一行的最大宽度为100个单位,如果我们在写某个字母的时候会使这行超过了100 个单位,那么我们应该把这个字母写到下一行。我们给定了一个数组 widths ,这个数组 widths[0] 代表 ‘a’ 需要的单位, widths[1] 代表 ‘b’ 需要的单位,…, widths[25] 代表 ‘z’ 需要的单位。
现在回答两个问题:至少多少行能放下S,以及最后一行使用的宽度是多少个单位?将你的答案作为长度为2的整数列表返回。
详细示例请移步官网
注意:
- 字符串 S 的长度在 [1, 1000] 的范围。
- S 只包含小写字母。
- widths 是长度为 26的数组。
- widths[i] 值的范围在 [2, 10]。
解题思路
模拟就完事了。
var numberOfLines = function(widths, s) {
const ret = [1,0] // 行 、最后一行的宽度
, A = 'a'.charCodeAt()
for(let c of s ){
let width = widths[c.charCodeAt() - A]
if(ret[1] + width > 100) {
ret[0] ++
ret[1] = 0
}
ret[1] += width
}
return ret
};
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/number-of-lines-to-write-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。