Redian新闻
>
LeetCode 力扣官方题解 | 806. 写字符串需要的行数

LeetCode 力扣官方题解 | 806. 写字符串需要的行数

公众号新闻


806. 写字符串需要的行数
「亚马逊、谷歌Google、奥多比Adobe」考题


题目描述

难易度:简单

我们要把给定的字符串 S 从左到右写到每一行上,每一行的最大宽度为 100 个单位,如果我们在写某个字母的时候会使这行超过了 100 个单位,那么我们应该把这个字母写到下一行。

我们给定了一个数组 widths ,这个数组 widths [0] 代表 'a' 需要的单位,widths [1] 代表 'b' 需要的单位,..., widths [25] 代表 'z' 需要的单位。

现在回答两个问题:至少多少行能放下 S ,以及最后一行使用的宽度是多少个单位?将你的答案作为长度为 2 的整数列表返回。

示例 1:

输入: widths = [10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10]S = "abcdefghijklmnopqrstuvwxyz"输出: [3, 60]解释: 所有的字符拥有相同的占用单位10。所以书写所有的26个字母,我们需要2个整行和占用60个单位的一行。
示例 2:
输入: widths = [4,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10]S = "bbbcccdddaaa"输出: [2, 4]解释: 除去字母'a'所有的字符都是相同的单位10,并且字符串 "bbbcccdddaa" 将会覆盖 9 * 10 + 2 * 4 = 98 个单位.最后一个字母 'a' 将会被写到第二行,因为第一行只剩下2个单位了。所以,这个答案是2行,第二行有4个单位宽度。
注:
  • 字符串 S 的长度在 [1, 1000] 的范围。

  • S 只包含小写字母

  • widths 是长度为 26 的数组。

  • widths [i] 值的范围在 [2, 10] 。


解决方案

方法一:直接遍历
思路与算法

我们从左到右遍历字符串 s 中的每个字母,lines 表示当前书写所需的行数,width 表示当前行已经使用的宽度。当遍历到一个字母 c 时:

  • 如果 width + widths [c] ≤ 100 ,此时那么更新 width = width + widths [c] 并保持 lines 不变;

  • 如果 width + widths [c] > 100 ,此时需要另起新的一行,那么此时 lines 的值加  1 ,并将 width 置为 widths [c] 。


代码

Python3

class Solution:    def numberOfLines(self, widths: List[int], s: str) -> List[int]:        MAX_WIDTH = 100        lines, width = 1, 0        for c in s:            need = widths[ord(c) - ord('a')]            width += need            if width > MAX_WIDTH:                lines += 1                width = need        return [lines, width]


Java
class Solution {    public static final int MAX_WIDTH = 100;
public int[] numberOfLines(int[] widths, String s) { int lines = 1; int width = 0; for (int i = 0; i < s.length(); i++) { int need = widths[s.charAt(i) - 'a']; width += need; if (width > MAX_WIDTH) { lines++; width = need; } } return new int[]{lines, width}; }}


C++

const int MAX_WIDTH = 100;
class Solution {public: vector<int> numberOfLines(vector<int>& widths, string s) { int lines = 1; int width = 0; for (auto & c : s) { int need = widths[c - 'a']; width += need; if (width > MAX_WIDTH) { lines++; width = need; } } return {lines, width}; }};


C#

public class Solution {    public static int MAX_WIDTH = 100;
public int[] NumberOfLines(int[] widths, string s) { int lines = 1; int width = 0; for (int i = 0; i < s.Length; i++) { int need = widths[s[i] - 'a']; width += need; if (width > MAX_WIDTH) { lines++; width = need; } } return new int[]{lines, width}; }}


C

#define MAX_WIDTH 100
int* numberOfLines(int* widths, int widthsSize, char * s, int* returnSize){ int lines = 1; int width = 0; int len = strlen(s); for (int i = 0; i < len; i++) { int need = widths[s[i] - 'a']; width += need; if (width > MAX_WIDTH) { lines++; width = need; } } int * ans = (int *)malloc(sizeof(int) * 2); *returnSize = 2; ans[0] = lines; ans[1] = width; return ans;}


Golang

func numberOfLines(widths []int, s string) []int {    const maxWidth = 100    lines, width := 1, 0    for _, c := range s {        need := widths[c-'a']        width += need        if width > maxWidth {            lines++            width = need        }    }    return []int{lines, width}}

JavaScript

const MAX_WIDTH = 100;var numberOfLines = function(widths, s) {    let lines = 1;    let width = 0;    for (let i = 0; i < s.length; i++) {        const need = widths[s[i].charCodeAt() - 'a'.charCodeAt()];        width += need;        if (width > MAX_WIDTH) {            lines++;            width = need;        }    }    return [lines, width];};

复杂度分析

  • 时间复杂度:O(n) ,其中 n 为字符串 s 的长度。需要遍历一遍字符串 s ,求出行数。
  • 空间复杂度:O(1) 。



BY / 

本文作者:力扣

编辑&版式:Vikki
声明:本文归“力扣”版权所有,如需转载请联系。


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
IEEE标准协会网络研讨会 | PRODUCT SHOWCASE: IEEE EQ NAVIGATOR陈丹青的西藏速写:赞美都是多余的​现在去一趟Costco要花多少钱?好市多(Costco)给出了答案LeetCode 力扣官方题解 | 953. 验证外星语词典太省了!Costco折扣只一天,直采直邮更省钱,COSTCO近期折扣大盘点来啦豹2坦克开赴战场,乌克兰开始战略反攻深度好文|刷完 LeetCode 是什么水平?能拿到什么等级的Offer?购物|Costco自产品牌Kirkland为啥这么这么物美价廉?为你揭晓Costco的七个成功小秘诀~Why it’s time to get shot of coffee meetings at work注意!眼下比有刷LeetCode更重要的事…Costco爆买折扣来了!少见的大包蔓越莓干打折了!尝遍COSTCO,美国零食新活动还有饼干蛋卷咖啡…IEEE Education Week主题演讲 | 主讲人:IEEE主席Saifur Rahman2023开年16天上岸谷歌,Leetcode刷题小抄背完,面试真的不一样…老鸟也难逃一劫,Leetcode刷题家今年是真的惨!随时随地线上Meeting!Google Meet 提供最新的 360 度虚拟背景功能~AI打LeetCode周赛进入前10%!秘诀:自然语言编程IEEE高级会员,IEEE中国联合会前任主席,IEEE北京分会前任主席冯进军当选北京“最美科技工作者”首次免费送!Leetcode刷题速通指南,转码留学生请低调使用!0基础留学生转码必备:LeetCode到底该怎么速通?生活中的数学:Why Eggs Are So Expensive?靠LeetCode刷题模板,学妹“开奖”字节offer!Java 近期新闻:字符串模板、Quarkus、Open Liberty、PrimeFaces、JobRunr、DevnexusLeetCode 力扣官方题解 | 590. N 叉树的后序遍历背完LeetCode刷题模板,真的不一样!(已拿字节offer)娃写字难看,不爱写字,咋办?CompletableFuture真香,可以替代CountDownLatch!LeetCode 力扣官方题解 | 2049. 统计最高分的节点数目刷完 LeetCode 是什么水平?能拿到什么等级的Offer?LeetCode 力扣官方题解 | 2055. 蜡烛之间的盘子雪天打卡人到中年学会做减法· 毕加索的减法Shell判断是否包含给定字符串Layoff潮,对传统刷LeetCode发起新挑战!LeetCode!曾经刷不会bfs,dfs…如今进亚麻注意!眼下比刷LeetCode更重要的事
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。