摘要:很奇葩的題目,先將轉(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]中即可。
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
摘要:題目題目解釋假設(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...
摘要:要求我們?cè)谥中沃匦屡帕羞@個(gè)字符串后,再按正常的從上到下,從左至右的順序輸出拼接好的字符串。因此對(duì)于每一個(gè)字符,我們判斷它應(yīng)該在哪一行,然后將它加到它所在行的字符序列的尾部。最后我們合并每一行,獲得最后的結(jié)果。 題目詳情 The string PAYPALISHIRING is written in a zigzag pattern on a given number of rows ...
摘要:題目解題方法以這樣的方式畫(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)...
摘要:給一個(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 ...
摘要:看到這道題總覺(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...
閱讀 2048·2023-04-25 15:24
閱讀 1586·2019-08-30 12:55
閱讀 1624·2019-08-29 15:27
閱讀 478·2019-08-26 17:04
閱讀 2416·2019-08-26 10:59
閱讀 1811·2019-08-26 10:44
閱讀 2207·2019-08-22 16:15
閱讀 2597·2019-08-22 15:36