#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 人评分
简单的a+b (C语言代码)浏览:594 |
字符串比较 (C语言代码)答案错误????浏览:641 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:644 |
数对 (C语言代码)浏览:762 |
判定字符位置 (C语言代码)浏览:849 |
矩阵转置 (C语言代码)浏览:855 |
C语言程序设计教程(第三版)课后习题8.4 (C语言代码)浏览:670 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:639 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:522 |
陶陶摘苹果2 (C++代码)浏览:578 |