看板 Visual_Basic 關於我們 聯絡資訊
我正在寫一個課題,是要丟入範圍很大,數字也很大的數值陣列 然後用各種排序方法來計算其排序所需要的時間 範圍是10^2到10^6 要用一千組數字的排序時間總合再除以一千取平均值 因為程式碼都有,所以我問題不是在於程式碼的寫法 而是在於其中一個QuickSort上 我設定一個數字k表示目前運算範圍為10的k次方 當k是2到3時,都可以正常的印出結果,排序出來也是正確的 但是在k等於4時,卻老是會卡在9523的這個數字上 然後就會出現 類型 'System.StackOverflowException' 的未處理例外狀況發生於 AHW1.exe 這一個錯誤訊息,程式無法繼續執行 說明上是要我檢查是否造成了無限迴圈或是無限遞迴 但是我很確定並沒有,因為當數字為一千時就可以正常排序一千次不出錯 只有在大於一萬時跑出這個錯誤 我確認過結束條件,很肯定結束條件是一定會發生的 (原本的QuickSort是有可能會無限遞迴,不過我修改過了) 我想可能畢竟還是遞迴太多次把堆疊占滿了 可是這樣一來我就沒辦法執行出我要的成果了 才一萬而已就超過,我的目標可是一百萬耶... 附上QuickSort的程式部分 Public Sub Quicksort(ByRef a() As Long, ByVal l As Long, ByVal r As Long) If l < r Then Dim s As Long s = Partitions(a, l, r) Quicksort(a, l, s - 1) Quicksort(a, s + 1, r) End If End Sub Public Function Partitions(ByRef a() As Long, ByVal l As Long, ByVal r As Long) As Long Dim p, i, j, temp As Long p = a(l) i = l j = r + 1 Do Do i = i + 1 Loop Until a(i) >= p Or i = r Do j = j - 1 Loop Until a(j) <= p Or j = l temp = a(i) a(i) = a(j) a(j) = temp Loop Until (i >= j) temp = a(i) a(i) = a(j) a(j) = temp temp = a(l) a(l) = a(j) a(j) = temp Return j End Function 都是照著書本上的虛擬碼來打的(確認過功能性了) (後面看似重複的部分,是我懶得去弄swap交換的偷懶寫法就是了) 用到Long是因為(理想中)數字高達一百萬的緣故 卡住的地方是在partition部分,當i=9523時出現的 (連跑兩次都是在同一個數字出錯) 請問,遇到這樣的問題,我有什麼方法能夠解決它呢? -- 其實我寫的MergeSort雖然也是用遞迴,但是就沒有出現這個錯誤訊息 只是,排序出來的結果根本就不對,明明都照著書本打了的說... 後來就不管它了,當作沒看到,只算它的時間就好了.... -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 122.126.49.7 ※ 編輯: Peruheru 來自: 122.126.49.7 (11/30 03:22)