午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

java - 求下面這道算法的解釋

瀏覽:134日期:2023-10-17 14:36:05

問題描述

已知長度為n的線性表A采用順序存儲結(jié)構,請寫一時間復雜度為O(n)、空間復雜度為O(1)的算法,該算法刪除線性表中所有值為item的數(shù)據(jù)元素。

void Delete(ElemType A[ ],int n)∥A是有n個元素的一維數(shù)組,本算法刪除A中所有值為item的元素。{i=1;j=n;∥設置數(shù)組低、高端指針(下標)。 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(); }}

java - 求下面這道算法的解釋

不知道該怎么改?求大佬解釋

問題解答

回答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:

哦,多出來是因為你輸出的個數(shù)錯了,刪除的過程沒問題。

刪除前,你的數(shù)組內(nèi)容是 2,34,4,4,5,共 5 個元素。

要刪除的內(nèi)容為 4,也就是說刪除后只剩 3 個元素,分別是 2,34,5

所以你的結(jié)果輸出只需要輸出數(shù)組的前 3 個,后面那兩個是作廢了的元素。

標簽: java
相關文章:
主站蜘蛛池模板: 男女猛烈无遮挡 | 手机看片日韩日韩 | 欧美专区在线视频 | 久草欧美 | 400部精品国偷自产在线观看 | 天天草天天操 | 国产一二三四视频 | 黄在线免费观看 | 欧美国产精品一区二区三区 | 亚洲在线看片 | 在线观看中文字幕第一页 | 亚洲综合中文字幕在线 | 爱啪啪av | 中文字幕在线看片 | 亚洲理论在线观看 | 久久美女免费视频 | av色哟哟 | 一本色道综合久久欧美日韩精品 | 亚洲四虎影院 | 日韩av中文字幕在线播放 | 亚洲最新在线视频 | 欧美gv在线观看 | 国产欧美一区二区三区视频在线观看 | 欧美一区二区免费视频 | 国产精品久久影院 | 黄色av一区二区三区 | 亚洲男女啪啪 | 亚洲欧美视频一区 | 99热精品免费 | 免费成人在线播放 | 性一交一乱一乱一视频 | 成人小视频在线播放 | 国产精品美女www爽爽爽视频 | 真实的国产乱xxxx在线91 | 91tv国产成人福利 | 淫语对白 | 三区四区在线观看 | 五月天av网站 | 欧美一级在线播放 | 亚洲欧美国产毛片在线 | 五月婷综合|