工作的算法:紅寶石遞歸算法問題
Given a rows x cols screen and a sentence represented by a list of non-empty words, find how many times the given sentence can be fitted on the screen.
Note:
A word cannot be split into two lines.
The order of words in the sentence must remain unchanged.
Two consecutive words in a line must be separated by a single space.
Total words in the sentence won't exceed 100.
Length of each word is greater than 0 and won't exceed 10.
1 ≤ rows, cols ≤ 20,000.
Example 1:
Input:
rows = 2, cols = 8, sentence = ["hello", "world"]
Output:
1
Explanation:
hello---
world---
The character '-' signifies an empty space on the screen.
Example 2:
Input:
rows = 3, cols = 6, sentence = ["a", "bcd", "e"]
Output:
2
Explanation:
a-bcd-
e-a---
bcd-e-
The character '-' signifies an empty space on the screen.
Example 3:
Input:
rows = 4, cols = 5, sentence = ["I", "had", "apple", "pie"]
Output:
1
Explanation:
I-had
apple
pie-I
had--
The character '-' signifies an empty space on the screen.
這裏是我的代碼:
def words_typing(sentence, rows, cols)
count_words(sentence, rows, cols, cols, 0, 0)
end
def count_words(sentence, rows, cols, remaining_space, row_num, word_idx)
return 0 if row_num == rows #keep going until out of rows, ends the recursion
word_idx = 0 if word_idx == sentence.length #reset the word back to the first
if remaining_space >= sentence[word_idx].length
if remaining_space == sentence[word_idx].length
return 1 + count_words(sentence, rows, cols, remaining_space - sentence[word_idx].length, row_num, word_idx + 1)
else #greater than 1
return 1 + count_words(sentence, rows, cols, remaining_space - sentence[word_idx].length - 1, row_num, word_idx + 1)
end
else #move to a new line, reset remaining space
return count_words(sentence, rows, cols, cols, row_num+1, word_idx)
end
end
代碼的工作原理如下。 word_idx是句子數組中單詞的索引。剩餘空間最初是列數。每當有足夠的空間放置單詞時,我會在同一行返回1 +函數調用,並保留下一個單詞和空格。如果剩餘空間> = 1 +字長,那麼我將考慮在兩個連續詞之間留有空格(這就是爲什麼我有額外的條件)。
如果word_idx比句子數組長,它會重置爲零。遞歸函數將繼續前進直到row_num現在大於在問題中提供給我們的行數。
但是,此代碼無效。我的輸出通常比正確的答案要大,但從概念上來說,我看起來都很好。任何人看到我的方法有問題?
非常感謝。它現在適用於大多數輸入。然而,在較大的測試案例中,我得到一個堆棧太深的錯誤。我試圖弄清楚爲什麼 - 我只做一個遞歸調用,取決於一個單詞是否可以以正確的方式放下...所以我的算法在別處是無效的嗎? – Sunny
@Sunny你對每個合適的單詞+ 1進行一次遞歸調用。我想。例如#1(rows = 3,cols = 6,sentence = [a,bcd,e])= 10個調用,例子#2(rows = 4,cols = 5,sentence = [I,had,apple,pie ])= 11個電話。 Ruby不是(我不知道Ruby語言的當前狀態)非常友好,所以你不應該使用太多的遞歸。您可以嘗試提高堆棧級別或使用「尾部調用優化」[您可以打開它](不確定它是否能在這種情況下工作)。這是很好的鏈接,解釋它http://rpanachi.com/2016/05/30/ruby-recursion-stack-size-tail-call-optimization –