【題目描述】
明明想在學校中請一些同學一起做一項問卷調查,為了實驗的客觀性,他先用計算機生成了N個1到1000之間的隨機整數(N≤100),對于其中重復的數字,只保留一個,把其余相同的數去掉,不同的數對應著不同的學生的學號。然后再把這些數從小到大排序,按照排好的順序去找同學做調查。請你協助明明完成“去重”與“排序”的工作。
【輸入】
有2行,第1行為1個正整數,表示所生成的隨機數的個數:N;
第2行有N個用空格隔開的正整數,為所產生的隨機數。
【輸出】
也是2行,第1行為1個正整數M,表示不相同的隨機數的個數。第2行為M個用空格隔開的正整數,為從小到大排好序的不相同的隨機數。
【輸入樣例】
10
20 40 32 67 40 20 89 300 400 15
【輸出樣例】
8
15 20 32 40 67 89 300 400
?剛剛我用sort函數排了
然后發現一年前我用桶排序的思想解決
不記得桶排序是什么了,所以記錄一下桶排序做法
#include <bits/stdc++.h>
using namespace std;int main()
{int i,j,k,n;cin>>n;int a[1100]={0};int x,cnt=0;for(i=1;i<=n;i++){cin>>x;if(a[x]==0)cnt++;a[x]++;}cout<<cnt<<endl;for(i=1;i<=1000;i++)if(a[i]!=0)cout<<i<<' ';return 0;
}