【LeetCode】806. 寫字符串需要的行數(shù)(Number of Lines To Write String)的解題思路

題目如下:(題目鏈接戳我

我們要把給定的字符串 S 從左到右寫到每一行上,每一行的最大寬度為100個(gè)單位嘶摊,如果我們?cè)趯懩硞€(gè)字母的時(shí)候會(huì)使這行超過了100 個(gè)單位,那么我們應(yīng)該把這個(gè)字母寫到下一行评矩。我們給定了一個(gè)數(shù)組 widths 叶堆,這個(gè)數(shù)組 widths[0] 代表 'a' 需要的單位, widths[1] 代表 'b' 需要的單位斥杜,...虱颗, widths[25] 代表 'z' 需要的單位。

現(xiàn)在回答兩個(gè)問題:至少多少行能放下S蔗喂,以及最后一行使用的寬度是多少個(gè)單位忘渔?將你的答案作為長度為2的整數(shù)列表返回。

示例 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個(gè)字母畦粮,
我們需要2個(gè)整行和占用60個(gè)單位的一行。

示例 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" 將會(huì)覆蓋 9 * 10 + 2 * 4 = 98 個(gè)單位.
最后一個(gè)字母 'a' 將會(huì)被寫到第二行宣赔,因?yàn)榈谝恍兄皇O?個(gè)單位了预麸。
所以,這個(gè)答案是2行儒将,第二行有4個(gè)單位寬度吏祸。

class Solution {
    public int[] numberOfLines(int[] widths, String S) {
        
    }
}

以下是我的解題思路:

  1. S 轉(zhuǎn)換為字符數(shù)組 chars
  2. 將字符數(shù)組chars強(qiáng)轉(zhuǎn)為int數(shù)組letters钩蚊;
  3. letters中每個(gè)元素都減去97贡翘,這樣就變成可以匹配數(shù)組下標(biāo)的int數(shù)組了;
  4. 循環(huán)letters砰逻,用letters中的元素作為下標(biāo)床估,取出widths中的每個(gè)數(shù)字,并求它們的和sum诱渤,當(dāng)sum大于100時(shí)丐巫,表明該換行了,將當(dāng)前數(shù)字賦值給sum勺美,并將行數(shù)line1递胧;
  5. 最后將行數(shù)linesum賦值給結(jié)果數(shù)組result,并返回赡茸;

代碼如下:

class Solution {
    public int[] numberOfLines(int[] widths, String S) {
        //將 S 轉(zhuǎn)換為字符數(shù)組
        char[] chars = S.toCharArray();
        //將字符數(shù)組轉(zhuǎn)換為 int 數(shù)組
        int[] letters = new int[chars.length];
        for (int i = 0; i < chars.length; i++) {
            //將 int 數(shù)組調(diào)整為與數(shù)組下標(biāo)對(duì)應(yīng)的 int 數(shù)組
            letters[i] = chars[i] - 97;
        }
        int sum = 0;
        int line = 1;
        for (int letter : letters) {
            //用 letters 數(shù)組元素作為下標(biāo)缎脾,依次取出每個(gè)字母占用的單位數(shù);
            //數(shù)量累加到一個(gè)和 sum 中
            sum += widths[letter];
            //當(dāng) sum 大于 100 時(shí)占卧,sum 賦值為當(dāng)前的單位數(shù)遗菠,并且行數(shù)加 1,繼續(xù)下輪循環(huán)华蜒;
            if (sum > 100) {
                sum = widths[letter];
                line++;
            }
        }
        int[] result = new int[2];
        result[0] = line;
        result[1] = sum;
        return result;
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末辙纬,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子叭喜,更是在濱河造成了極大的恐慌贺拣,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件捂蕴,死亡現(xiàn)場離奇詭異譬涡,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)啥辨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門涡匀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人溉知,你說我怎么就攤上這事陨瘩±拔耍” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵拾酝,是天一觀的道長。 經(jīng)常有香客問我卡者,道長蒿囤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任崇决,我火速辦了婚禮材诽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘恒傻。我一直安慰自己脸侥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布盈厘。 她就那樣靜靜地躺著睁枕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪沸手。 梳的紋絲不亂的頭發(fā)上外遇,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音契吉,去河邊找鬼跳仿。 笑死,一個(gè)胖子當(dāng)著我的面吹牛捐晶,可吹牛的內(nèi)容都是我干的菲语。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼惑灵,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼山上!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起英支,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤胶哲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后潭辈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸯屿,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年把敢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寄摆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡修赞,死狀恐怖婶恼,靈堂內(nèi)的尸體忽然破棺而出桑阶,到底是詐尸還是另有隱情,我是刑警寧澤勾邦,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布蚣录,位于F島的核電站,受9級(jí)特大地震影響眷篇,放射性物質(zhì)發(fā)生泄漏萎河。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一蕉饼、第九天 我趴在偏房一處隱蔽的房頂上張望虐杯。 院中可真熱鬧,春花似錦昧港、人聲如沸擎椰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽达舒。三九已至,卻和暖如春叹侄,著一層夾襖步出監(jiān)牢的瞬間休弃,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國打工圈膏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留塔猾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓稽坤,卻偏偏與公主長得像丈甸,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子尿褪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容