java - 求下面這道算法的解釋
問題描述
已知長度為n的線性表A采用順序存儲結構,請寫一時間復雜度為O(n)、空間復雜度為O(1)的算法,該算法刪除線性表中所有值為item的數據元素。
void Delete(ElemType A[ ],int n)∥A是有n個元素的一維數組,本算法刪除A中所有值為item的元素。{i=1;j=n;∥設置數組低、高端指針(下標)。 while(i<j) {while(i<j && A[i]!=item)i++; ∥若值不為item,左移指針。 if(i<j)while(i<j && A[j]==item)j--;∥若右端元素為item,指針左移 if(i<j)A[i++]=A[j--];}
改寫之后運行不出來,下面是改寫后的
package 線性表;public class Work_10 { public Work_10(){int[] arr={2,34,4,4,5};int item=4;delete(arr,item,arr.length-1);for(int a:arr){ System.out.print(a+' ');} } public static void delete(int[] array,int item,int n){int i=0,j=n;while(i<j){ while(i<j&&array[i]!=item) i++; if(i<j) while(i<j&&array[j]==item) j--; if(i<j){array[i++]=array[j--]; }} } public static void main(String[] args) {new Work_10(); }}
不知道該怎么改?求大佬解釋
問題解答
回答1:要想刪除,先搜索,后刪除,給你個搜索的,剩下的自己思考下寫個變種就可以了。
public static int search(byte[] a,int n, byte item) {int low = 0;int high = n - 1;while (low <= high) { int mid = (low + high) >>> 1; byte midVal = a[mid]; if (midVal < item)low = mid + 1; else if (midVal > item)high = mid - 1; elsereturn mid; // 找到item}return -(low + 1); // 沒找到item }回答2:
哦,多出來是因為你輸出的個數錯了,刪除的過程沒問題。
刪除前,你的數組內容是 2,34,4,4,5,共 5 個元素。
要刪除的內容為 4,也就是說刪除后只剩 3 個元素,分別是 2,34,5
所以你的結果輸出只需要輸出數組的前 3 個,后面那兩個是作廢了的元素。
相關文章:
1. 數組按鍵值封裝!2. java - web項目中,用戶登陸信息存儲在session中好 還是cookie中好,取決于什么?3. angular.js - webpack build后的angularjs路由跳轉問題4. Mysql取下一條記錄5. mysql - 查詢字段做了索引為什么不起效,還有查詢一個月的時候數據都是全部出來的,如果分拆3次的話就沒問題,為什么呢。6. mysql - 大部分數據沒有行溢出的text字段是否需要拆表7. 老師,怎么不講一次性添加多個數據8. python - linux 下用wsgifunc 運行web.py該如何修改代碼9. pdo - mysql 簡單注入疑問10. 表格對其 只涉及到對其,沒有涉及到大小,長寬還有背景色類的嗎
