#include <stdio.h> #include <stdlib.h> int main(void) { int M, i, j, temp; int *A; while(scanf("%d", &M) != EOF) { A = (int *)malloc(sizeof(int) * M); for(i = 0; i < M; i++) { scanf("%d", &A[i]); } for(i = 0; i < M; i++) { for(j = i + 1; j < M; j++) { while(A[i] == A[j] && j < M )//将重复的值与数组最后一个书交换,并将M的值减一 { //注意J<M这一点很重要 temp = A[j]; A[j] = A[M - 1]; A[M - 1] = temp; M -= 1; } if(A[i] > A[j]) { temp = A[i]; A[i] = A[j]; A[j] = temp; } } } printf("%d\n", M); for(i = 0; i < M; i++) printf("%d ", A[i]); printf("\n"); free(A); } return 0; }
0.0分
0 人评分