java - 希爾排序的疑問
問題描述
public static void sort(long[] arr){int h = 1; // 初始化間隔// 計算最大間隔while(h < arr.length / 3){ h = 3 * h + 1;}while(h > 0){ long temp = 0; for(int i = h; i < arr.length; i++){temp = arr[i]; // temp等于數組第i個元素的值int j = i;while(j > h - 1 && arr[j - h] > temp){ arr[j] = arr[j - h]; j-=h;}arr[j] = temp; } // 下一個h值 h = (h - 1) / 3;} }
疑問:while(j > h - 1 && arr[j - h] > temp) 這行代碼,j > h - 1; 不懂為啥 j > 0 會出現數組越界異常,而 j > h - 1 就不會。
@奔跑如風 ,能幫忙看看嗎?謝謝~
問題解答
回答1:j > h - 1 && arr[j - h] > temp
這兩句合起來看,你的j>0無法保證j - h是大于等于0的。
回答2:我也覺得可能是j>0無法滿足j-h>=0的情況。你可以把arr數組開的很大,如果還錯的話那就肯定是這個原因,但是從代碼上看,我覺得j-h始終是大于等于0的。回頭幫你調試下分析分析。
相關文章:
1. java - MySQL中,使用聚合函數+for update會鎖表嗎?2. 如何分別在Windows下用Winform項模板+C#,在MacOSX下用Cocos Application項目模板+Objective-C實現一個制作游戲的空的黑窗口?3. javascript - 如何清除向可編輯的(contenteditable)元素里粘貼的文本的標簽和樣式?4. java - Atom中文問題5. angular.js - 百度支持_escaped_fragment_嗎?6. 這種數據怎么合并啊?7. nginx - 關于vue項目部署到ngnix后出現的問題8. java - spring-data Jpa 不需要執行save 語句,Set字段就可以自動執行保存的方法?求解9. javascript - 如何使用loadash對[object,object,object]形式的數組進行比較10. java - C語言算法題-韓信點兵 求解?
