刪除一個(gè)數(shù)組中的重復(fù)元素 c語(yǔ)言如何刪除數(shù)組中重復(fù)元素?
c語(yǔ)言如何刪除數(shù)組中重復(fù)元素?1/*2想法:3將字符串存儲(chǔ)在字符數(shù)組a中,設(shè)置要復(fù)制到數(shù)組B的值,遍歷B的每個(gè)元素4素?cái)?shù),與a中的每個(gè)元素進(jìn)行比較,如果有相同的,則將B中的相應(yīng)元素設(shè)置為-1。5個(gè)輸出
c語(yǔ)言如何刪除數(shù)組中重復(fù)元素?
1/*
2想法:
3將字符串存儲(chǔ)在字符數(shù)組a中,設(shè)置要復(fù)制到數(shù)組B的值,遍歷B的每個(gè)元素
4素?cái)?shù),與a中的每個(gè)元素進(jìn)行比較,如果有相同的,則將B中的相應(yīng)元素設(shè)置為-1。
5個(gè)輸出元素非-1 in B.
6*/
7#-包括和ltstdio。H>
8#-包含字符串(&L)。H>
9 char a[100],B[100
]10 void del(int index,int len){
11 for(int i=0I<leni){
12 if(index==i)continue//下標(biāo)相同,即不比較同一個(gè)元素并進(jìn)入下一個(gè)循環(huán)
13 if(B[index]==a[i])B[index]=-1//使用同一個(gè)元素,設(shè)為-1
14}
15}
16 int main(){
17 gets(a)
18 memcpy(B,a,sizeof(a))//將a的元素復(fù)制到B
19 int len=strlen(a)//求a的長(zhǎng)度
20 for(int i=0I<leni){
21 del(i,len)
22}
23 for(int i=0I<leni){//輸出B中的非1元素
24 if(B[i]!=-1){
]25 printf(%C“,B[i])
26}
]27}
28返回0
29}
考慮使用for循環(huán)或while循環(huán)。以下是一個(gè)可供參考的測(cè)試方法。如果是包含大量數(shù)據(jù)的數(shù)組,則可以考慮更有效的方法。如果是C語(yǔ)言編程,其實(shí)道理幾乎是一樣的。創(chuàng)建一個(gè)新的可變長(zhǎng)度數(shù)組來(lái)保存元素組中提取的元素。以確保刪除重復(fù)的元素。根據(jù)LabVIEW的特點(diǎn),利用LabVIEW的一維數(shù)組查找功能,將從原始數(shù)組中提取的元素與新數(shù)組中的所有元素進(jìn)行比較。如果找到相同的元素,則不將該元素添加到新數(shù)組中;如果找不到相同的元素,則將該元素添加到新數(shù)組中。
怎樣用一個(gè)方法去掉一個(gè)數(shù)組的重復(fù)元素?
Int elimination(Int a[]Int count){//刪除數(shù)組Int i,J,K中的重復(fù)元素(i=0,i< count i){對(duì)于(J=i 1,J< count J){如果(a[J]==a[i]){對(duì)于(K=J 1,K< count K)a[K-1]=a[K]count--J--}返回計(jì)數(shù)}