배열에 있는 동일한 숫자를 삭제해 보십시오. 결과 배열은 고유한 요소로 구성됩니다.
배열의 중복 요소를 삭제하는 논리 다음과 같습니다 -
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