배열에 있는 동일한 숫자를 삭제해 보십시오. 결과 배열은 고유한 요소로 구성됩니다.
배열의 중복 요소를 삭제하는 논리 다음과 같습니다 -
for(i=0;i<number;i++){
for(j = i+1; j < number; j++){
if(a[i] == a[j]){
for(k = j; k <number; k++){
a[k] = a[k+1];
}
j--;
number--;
}
}
} 중복 삭제 후 숫자를 표시하는 논리는 다음과 같습니다. -
for(i=0;i<number;i++){
printf("%d ",a[i]);
} 프로그램
다음은 배열에서 중복 요소를 삭제하는 C 프로그램입니다.
#include<stdio.h>
#include<stdlib.h>
int main(){
int a[50],i,j,k, count = 0, dup[50], number;
printf("Enter size of the array\n");
scanf("%d",&number);
printf("Enter Elements of the array:\n");
for(i=0;i<number;i++){
scanf("%d",&a[i]);
dup[i] = -1;
}
printf("Entered element are: \n");
for(i=0;i<number;i++){
printf("%d ",a[i]);
}
for(i=0;i<number;i++){
for(j = i+1; j < number; j++){
if(a[i] == a[j]){
for(k = j; k <number; k++){
a[k] = a[k+1];
}
j--;
number--;
}
}
}
printf("\nAfter deleting the duplicate element the Array is:\n");
for(i=0;i<number;i++){
printf("%d ",a[i]);
}
} 출력
위의 프로그램을 실행하면 다음과 같은 결과가 나온다 -
Enter size of the array 10 Enter Elements of the array: 1 1 2 4 3 5 6 5 7 1 Entered element are: 1 1 2 4 3 5 6 5 7 1 After deleting the duplicate element, the Array is: 1 2 4 3 5 6 7