我需要找出數組之間最長的方式(從大到小)。 我試過編寫recursive
函數,得到了java.lang.StackOverflowError
,但由於缺乏知識,我不明白爲什麼會發生這種情況。遞歸java堆棧溢出錯誤
首先,我初始化數組,並用隨機數字填充:
public long[] singleMap = new long[20];
for (int i = 0; i < 20; i++) {
singleMap[i] = (short) random.nextInt(30);
}
於是,我試圖找到掰着指頭數最長的途徑(例如{1,4,6,20, 19,16,10,6,4,7,6,1 ...})並返回計數這樣的數字。
public int find(long[] route, int start) {
if (route[start] > route[start + 1]) {
find(route, start++);
} else {
return start;
}
return start;
}
所以這裏的日誌:
08-23 13:06:40.399 4627-4627/itea.com.testnotification I/dalvikvm: threadid=1: stack overflow on call to Litea/com/testnotification/MainActivity;.find:ILI
08-23 13:06:40.399 4627-4627/itea.com.testnotification I/dalvikvm: method requires 36+20+12=68 bytes, fp is 0x4189e318 (24 left)
08-23 13:06:40.399 4627-4627/itea.com.testnotification I/dalvikvm: expanding stack end (0x4189e300 to 0x4189e000)
08-23 13:06:40.400 4627-4627/itea.com.testnotification I/dalvikvm: Shrank stack (to 0x4189e300, curFrame is 0x418a3e88)
08-23 13:06:40.400 4627-4627/itea.com.testnotification D/AndroidRuntime: Shutting down VM
08-23 13:06:40.400 4627-4627/itea.com.testnotification W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x41a8ed40)
08-23 13:06:40.414 4627-4627/itea.com.testnotification E/AndroidRuntime: FATAL EXCEPTION: main
Process: itea.com.testnotification, PID: 4627
java.lang.StackOverflowError
at itea.com.testnotification.MainActivity.find(MainActivity.java:46)
at itea.com.testnotification.MainActivity.find(MainActivity.java:46)
我明白任何解釋,因爲所有相關問題並沒有幫助我。如果我的功能有問題,請糾正或解釋。
編輯
我忘記說了,我用for
從每個 「點」
for (int i = 0; i < singleMap.length - 1; i++) {
int x = find(singleMap, i);
System.out.println("steps = " + x);
}
'開始++'返回start'的'原始值,並增加了1到'start' ** **之後。在++返回值之前,'++ start'在'start' **中加1。 –
你應該添加一個Log.i(「Start」,start.toString());到你的查找方法作爲第一行,所以你看看會發生什麼。 – Squirrelkiller