解题思路:该题目分为两大主要目的,第一是要对输入的数进行排序,第二是对输入的数进行筛同。排序的方法很多,仅做参考,筛同时首先利用比较将相同的数选出来,然后将相同的数进行赋值,赋值成-1,后续会利用if语句,将小于0的数删除,达到筛同的目的。
参考代码:
#include<stdio.h> int main() { int N; int b; scanf("%d", &N); int a[1000]; int sum = 0; for (int i = 0; i < N; i++) { scanf("%d", &a[i]); } for (int i = 0;i < N; i++) { for (int j = 0; j < N - i; j++) { if (a[j] > a[j + 1]) { b = a[j + 1]; a[j + 1] = a[j]; a[j] = b; } } }//排序 for (int i = 1; i < N+1; i++) { for (int j = i + 1; j < N+1; j++) { if (a[j] == a[i]) { a[i] = -1; } } }//把相同的数赋值成-1,方便后续的删除 for (int i = 1; i < N+1; i++) { if (a[i] > 0) { sum = sum + 1; } } printf("%d\n", sum);//确定删除相同数后的个数 for (int i = 1; i < N+1; i++) { if (a[i] > 0) { printf("%d ", a[i]); } }//打印数组 return 0; }
0.0分
2 人评分