2016-03-04 93 views
2

我正在做一個類的任務,但我不知道爲什麼我爲這兩個方法編寫的代碼不起作用。有點新的遞歸方法,我不知道爲什麼這不起作用

對於第一種方法,我試圖將數組中的當前位置與下一個位置進行比較,如果下一個位置較大,則它將變爲最大。換句話說,當前位置的整數變成最大。使用遞歸方法調用通過數組後,它將返回數組中最大的int值。

// This method takes an integer array as well as an integer (the starting index) and returns the largest number in the array. 
public int largestRec(int[] arr, int pos) 
{ 
    // TODO: implement this method 
    int largest = arr[pos]; 
     if(pos == arr.length-1) 
    { 
     return largest; 
    } 
    else 
    { 
     if(arr[pos] < arr[pos+1]) 
     { 
      largest = arr[pos+1]; 
     } 
     else 
     { 
      largest = arr[pos]; 
     } 
     pos++; 
     largestRec(arr, pos); 
    } 
    return largest; // replace this statement with your own return 
} 

第二種方法。我想要做的是讓它通過遞歸方法調用傳遞一個較小版本的字符串,然後當測試類調用方法時,它將打印出字符串的反向。

// This method reads a string and returns the string in the reversed order. 
public String reverseStringRec(String s) 
{ 
    // TODO: implement this method 
    String reverse; 
    int pos = 0; 
    if(s=="" || s.length() <= 1) 
    { 
     return s; 
    } 
     else 
    { 
     reverse = reverseStringRec(s.substring(1)) + s.charAt(0); 
    } 
    return reverse; // replace this statement with your own return 
} 

我不知道如何編寫代碼,使之做到這一點(的任務,我只能修改方法,而不是外面的變量/方法/允許類),所以我會很感激的任何建議/幫助你可以提供。如果您需要更多信息,我會很樂意提供。謝謝。

編輯: 我的問題是,第一種方法不會返回最大。對於我的測試數組,它通常會打印第一個int,或者第二個(如果它大於第一個,但不檢查其餘)。對於第二個問題,我的測試課(由我的教授提出)給出了'串索引超出範圍'的消息,我不知道如何解決這個問題。我看着Jason的建議,並將建議的解決方案,但它似乎並沒有工作我的情況

EDIT2:reverseStringRec()的新版本現在可現在我需要修復largestRec()問題仍然是開放的,如果任何人都可以提供任何幫助

編輯3:雖然我修復了reverseStringRec(),但是有人給出了一個包含for循環的答案,我沒有提到我不能使用循環來完成這個任務,所以我爲給您帶來的不便表示歉意。如果您需要查看它現在產生的結果,可以使用下面的最大記錄()。

試驗3:最大(10)==> [傳遞] 預期:10個 此致:10

測試4:最大(10,20,30,40,50,60)==> [失敗] 預期:60個 此致:20

測試5:最大(70,20,30,40,50,10)==> [傳遞] 預期:70個 此致:70

測試6:最大(70,20,100,40,50,10)==> [失敗] 預計:100 你的:70

編輯4:找到兩種方法的解決方案。對於largestRec(),請看下面提供的解決方案。對於reverseStringRec(),您可以使用本文中的或以下建議的之一。

+0

你的'最大()'方法看起來不對,你甚至沒有使用它。 –

+0

歡迎來到StackOverflow。請閱讀並遵守幫助文檔中的發佈準則。 [最小,完整,可驗證的示例](http://stackoverflow.com/help/mcve)適用於此處。在您發佈代碼**和**準確描述問題之前,我們無法有效幫助您。在這篇文章中(這應該是兩個獨立的文章),你沒有顯示實際的問題。 「...不工作」不是問題描述。 – Prune

+0

@TimBiegeleisen我知道這是錯的,這就是爲什麼我問。我不知道如何爲它編寫代碼。 –

回答

0

查看這些找到最大數字並反轉字符串的方法。你的解決方案非常接近。這是我將如何實現這些。你需要在索引中跟蹤數組的最大數量,否則你可以做的就是傳入第一個數字並假定它是最大的數字,並且每次找到最大的數字時,一旦到達數組的末尾,就返回最大。

public String reverseString(String str) 
{ 
    if(str.length()==1){ 
     return str; 
    } 
    return str.charAt(str.length() - 1) + reverseString(str.substring(0, str.length() - 1)); 

} 
// initialize pos to 0 
public int getLargest(int[] arr, int pos) 
{ 
    int largest = arr[pos]; 
    if (pos + 1 >= arr.length) { 
     return largest; 
    } 

    int second = getLargest(arr, pos + 1); 
    return largest > second ? largest : second; 
} 
+0

感謝您的回答,但我無法使用索引,因爲我不允許修改該作業的方法參數。我只能使用(int [] arr,int pos)。如果你有一個解決方案,只需要這兩個參數就可以從數組中獲得最大的int,我真的很感激它。 –

+0

對不起,不知道這是一個限制,它完成了。必須給它一個想法,3個參數是我想到的第一件事情。 –

+0

感謝您的解決方案。我認爲我的原始代碼沒有用,因爲我沒有int第二。不確定,但您的解決方案既快速又簡單。 –

0

逆轉字符串用遞歸方法,你可以這樣來做:公共

static String reverseStr(String str) { 
     if (str.length() == 1) 
      return str; 
     else 
      return str.charAt(str.length()-1) + reverseStr(str.substring(0, str.length()-1)); 
    } 

    public static void main(String[] args) { 
     System.out.println(reverseStr("String to be reversed")); 
    } 

另一個簡單的辦法扭轉一個字符串(不遞歸):

public static String reverseStringRec(String s) { 
     String reverse = ""; 
     int pos = 0; 
     for (int i = s.length()-1; i >= 0; i--) { 
      reverse += s.charAt(i); 
      pos++; 
     } 
     return reverse; 
    } 

    public static void main(String[] args) { 
     System.out.println(reverseStringRec("String to be reversed")); 
    } 

爲了您的第一部分的問題,這裏是解決方案:

static int findMax(int[] arr, int length) { 
     if (length == 1) { 
      return arr[0]; 
     } 
     return max(findMax(arr, length - 1), arr[length - 1]); 
    } 

    private static int max(int num1, int num2) { 
     return num1>num2 ? num1 : num2; 
    } 

    public static void main(String[] args) { 
     int[] arr = {10, 20, 3, 55, 200, 33}; 
     System.out.println(findMax(arr, arr.length)); 
    } 
+2

我很感激你花時間做出了代碼,但對於這個任務,我必須使用沒有任何循環的遞歸方法調用。對不起,我忘了在我的帖子中提到。 –

+0

不用擔心。我注意到你已經排序了。 並且您的其他問題已經有了一個建議的解決方案。 乾杯 – goncalopinto

+0

我剛剛編輯了我的答案o滿足你在問題中要求的內容(字符串反向)。 – goncalopinto

1

就在蝙蝠身上,問題與第二種方法。在它裏面,你遞歸地調用reverseString方法,並且它的參數是一個子字符串。然而,在這個子字符串中,你試圖使子字符串比原始參數s更長 - 實質上,通過包含s.length()+ 1,substring()方法嘗試創建一個子字符串,其索引爲s .length()+ 1,不存在。

對於實際反轉方法的字符串輸入,我強烈推薦使用charAt()方法。

+0

是的。我意識到這一點並將其刪除。我將使用reverseStringRec()的版本來編輯我的帖子。現在,我只需要修復largestRec()。 –

相關問題