成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[LeetCode] ZigZag Conversion

TIGERB / 2113人閱讀

摘要:很奇葩的題目,先將轉(zhuǎn)化為字符數(shù)組,便于操作。再看要求轉(zhuǎn)化為多少行,就建立多大的數(shù)組。

Problem

The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like this: (you may want to display this pattern in a fixed font for better legibility)

P   A   H   N
A P L S I I G
Y   I   R

And then read line by line: "PAHNAPLSIIGYIR"
Write the code that will take a string and make this conversion given a number of rows:

string convert(string text, int nRows);

convert("PAYPALISHIRING", 3) should return "PAHNAPLSIIGYIR".

Note

很奇葩的題目,PAYPAL IS HIRING.
先將s轉(zhuǎn)化為字符數(shù)組c,便于操作。
再看nRows要求轉(zhuǎn)化為多少行,就建立多大的StringBuilder數(shù)組sb[]。注意,建立完之后要用for循環(huán)對(duì)每一個(gè)StringBuilder[i]初始化:sb[i] = new StringBuilder();
然后用指針i循環(huán)字符數(shù)組c:順序從0到nRows-1每一行放入一個(gè)字符c[i++],然后逆序從nRows-2到1每一行放入一個(gè)字符c[i++],直到i == c.length.
以上就將豎向ZigZag形式的字符串以橫向讀取順序存入了數(shù)組sb中,將sb[i]中的所有字符串都合并到sb[0]中即可。

Solution
public class Solution {
    public String convert(String s, int nRows) {
        char[] c = s.toCharArray();
        int len = c.length;
        StringBuffer[] sb = new StringBuffer[nRows];
        for (int i = 0; i < sb.length; i++) sb[i] = new StringBuffer();
    
        int i = 0;
        while (i < len) {
            for (int idx = 0; idx < nRows && i < len; idx++) // vertically down
                sb[idx].append(c[i++]);
            for (int idx = nRows-2; idx >= 1 && i < len; idx--) // obliquely up
                sb[idx].append(c[i++]);
        }
        for (int idx = 1; idx < sb.length; idx++)
            sb[0].append(sb[idx]);
        return sb[0].toString();
    }
}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/64785.html

相關(guān)文章

  • ZigZag Conversion - LeetCode JavaScript

    摘要:題目題目解釋假設(shè)我們輸入的就是上面的字符串在取不同值的時(shí)候大家看我用做的簡(jiǎn)易的圖看完圖應(yīng)該就明白了這個(gè)題目到底是什么意思這個(gè)題的難點(diǎn)在于找規(guī)律只要找到了規(guī)律解決這個(gè)題并不難規(guī)律如下第一行或者最后一行元素之間的間隔為中間部分間隔分別是依 題目 The string PAYPALISHIRING is written in a zigzag pattern on a given n...

    G9YH 評(píng)論0 收藏0
  • leetcode 6 ZigZag Conversion

    摘要:要求我們?cè)谥中沃匦屡帕羞@個(gè)字符串后,再按正常的從上到下,從左至右的順序輸出拼接好的字符串。因此對(duì)于每一個(gè)字符,我們判斷它應(yīng)該在哪一行,然后將它加到它所在行的字符序列的尾部。最后我們合并每一行,獲得最后的結(jié)果。 題目詳情 The string PAYPALISHIRING is written in a zigzag pattern on a given number of rows ...

    Dr_Noooo 評(píng)論0 收藏0
  • LeetCode_String #6. ZigZag Conversion (Easy)

    摘要:題目解題方法以這樣的方式畫(huà)出更方便看出它的規(guī)律。當(dāng)?shù)臅r(shí)候,第一行和最后一行每次都是可以設(shè)一個(gè)再來(lái)看,中間的行數(shù)除了第一行和最后一行,跳的規(guī)律發(fā)生變化,其實(shí)每次還是存在,只不過(guò)中間多了一些。 題目:ZigZag Conversion showImg(/img/bVz1DU); 解題方法: showImg(/img/bVz1Eb); 以這樣的方式畫(huà)出String更方便看出它的規(guī)律。 1 當(dāng)...

    Corwien 評(píng)論0 收藏0
  • LeetCode 6: ZigZag Conversion (JAVA)

    摘要:給一個(gè)要求按豎字方法去排列再橫向讀出,給定行數(shù)。若則程序輸出應(yīng)為若程序輸出應(yīng)為分析找規(guī)律,將每行當(dāng)作一個(gè)研究對(duì)象,找出每個(gè)字母在原字符串中的代數(shù)規(guī)律。若文章中有錯(cuò)誤或者各路大神有更好解法,歡迎評(píng)論。 給一個(gè)String: PAYPALISHIRING 要求按豎Z字方法去排列再橫向讀出,給定行數(shù)R。 若 R = 3: P A H N A P L S I I G Y I ...

    csRyan 評(píng)論0 收藏0
  • LeetCode.6 Z 字形變換(zigzag-conversion)(JS)

    摘要:看到這道題總覺(jué)得眼熟,做完之后恍然大悟,這不就是小學(xué)數(shù)學(xué)做的找規(guī)律一題目字形變換將一個(gè)給定字符串根據(jù)給定的行數(shù),以從上往下從左到右進(jìn)行字形排列。一當(dāng)然是因?yàn)樽罱鼘?shí)在太忙了捂臉,幾乎周周誰(shuí)遭得住。 看到這道題總覺(jué)得眼熟,做完之后恍然大悟,這不就是小學(xué)數(shù)學(xué)做的找規(guī)律 一、題目 Z 字形變換: 將一個(gè)給定字符串根據(jù)給定的行數(shù),以從上往下、從左到右進(jìn)行 Z 字形排列。比如輸入字符串為 LEET...

    cheukyin 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

TIGERB

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<