每次從第一個數(shù)據(jù)節(jié)點開始,從該節(jié)點后查找相同數(shù)據(jù)的節(jié)點,找到刪除之。Node *p,*q,*s;if(head==NULL || head-next==NULL)return;q=p=head-next;//單鏈表刪除節(jié)點,必須持有前一個節(jié)點,否則無法刪除。
我們提供的服務(wù)有:成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、泉山ssl等。為數(shù)千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的泉山網(wǎng)站制作公司
你只是對相鄰的元素進行比較,所以只能刪除相鄰且相同的元素。如果按照你的思想,則要先經(jīng)排序后的鏈表,再執(zhí)行Puge(L)才能刪除鏈表中所有的相同的元素。
非遞減的話,就是遞增排序了。就在排序時候作個比較,如果值相同,就不要連接,不就可以了。
應(yīng)該不對吧,我總覺得邏輯有錯誤,特別是第二個For語句,感覺沒必要吧,我寫了一個。你看看。
void DelCom(SLink *&ha,SLink *&hb)//你只刪除了L1 的元素,而題目的要求是刪除L1中和同L2相同的元素。
直接移除非常麻煩,需要遍歷集合,然后再去判斷每一個元素是否重復(fù)??梢宰咔€救國路線。使用linq to entity ,用linq查詢語句把集合中把不相同的元素查詢出來。
最好的辦法是用Set,因為Set里面存放的數(shù)據(jù)是不重復(fù)的。如果你不想用Set,那還可以向下面這樣處理。List list_tmp = new ArrayList(); //建立一個用于臨時存放不重復(fù)list元素的List集合。
集合中的確不能有兩個相同的元素。因為集合的三要素:確定性、互異性、無序性。
} } 在代碼中,刪除元素后,需要把下標(biāo)減一。這是因為在每次刪除元素后,ArrayList會將后面部分的元素依次往上挪一個位置(就是copy),所以,下一個需要訪問的下標(biāo)還是當(dāng)前下標(biāo),所以必須得減一才能把所有元素都遍歷完。
java中,list是可以重復(fù)的,但是set就不能重復(fù)了。在java中,list成為列表,而set則是集合,集合中的元素是不可以重復(fù)的,但是列表中的是可以的,所以,list里面的元素是可以重復(fù)的。
②,用Begin=0,end=ArraySize-1,每次遍歷begin到end之間的元素,如果有重復(fù)的,則將重復(fù)元素與end元素交換,--end,遍歷完畢之后++begin,當(dāng)begin達到end的時候停止。
利用雙重循環(huán),將每個值依次與其后面的值相比較,如果有相同的則刪除該元素即可。刪除時,可以使用將后面元素依次向前移動一位,同時總長度減一的方式。
根據(jù)你的意思,我來寫寫,沒在工具上寫,沒環(huán)境,你自己編譯下,應(yīng)該只有小錯誤。
2011-07-19 C語言編程序,要求從鍵盤輸入10個整數(shù)存入一維數(shù)組。 6 2014-04-17 編寫程序,定義一數(shù)組接收鍵盤輸入的10個數(shù),然后刪除數(shù)組中所... 1 2012-05-13 編寫程序,從鍵盤輸入10個整數(shù),保存在一個數(shù)組中 。
比如你已經(jīng)定義了一個數(shù)組(從小到大排)a[n]刪除: 刪除數(shù)據(jù) X for(i=0;in;i++){if(x==a[i]) break;}//定位到X的位置 if(i==n-1) {printf(刪除錯誤,沒有%d這個元素。