HJ3 明明的随机数

描述

明明生成了NN个1到500之间的随机整数。请你删去其中重复的数字,即相同的数字只保留一个,把其余相同的数去掉,然后再把这些数从小到大排序,按照排好的顺序输出。

数据范围: 1 \le n \le 1000 \ 1≤n≤1000 ,输入的数字大小满足 1 \le val \le 500 \ 1≤val≤500

输入描述

第一行先输入随机整数的个数 N 。 接下来的 N 行每行输入一个整数,代表明明生成的随机数。 具体格式可以参考下面的"示例"。

输出描述

输出多行,表示输入数据处理后的结果

方法一 set集合,set内部已经排好序

#include
#include
using namespace std;
int main() {
    int n;
    while(cin>>n) {    //输入每组数据的个数
        set<int> order;    //使用set容器可以自动实现去重和排序的操作,这里很关键
        for(int i=0;i<n;i++) {
            int num;
            cin>>num;    //输入数字
            order.insert(num);    //插入到容器order中
        }
        set<int>::iterator it;    //set类型迭代器
        for(it=order.begin();it!=order.end();it++){
            cout<<*it<<endl;    //遍历输出
        }
    }
    return 0;
}

方法二 数组标记法

#include 
using namespace std;

int arr[501];//用于遍历

int main(){
    int n;cin>>n;
    while(n--){
        int num;cin>>num;
        arr[num] = 1;
    }
    for(int i = 1;i<501;i++){
        if(arr[i]==1){
            cout<<i<<endl;
        }
    }
    return 0;
}

你可能感兴趣的:(算法,c++,算法,数据结构)