[JLOI2011]不重复数字


Description

给出N个数,要求把其中重复的去掉,只保留第一次出现的数。
例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 18 3 19 6 5 4。

Input

输入第一行为正整数T,表示有T组数据。
接下来每组数据包括两行,第一行为正整数N,表示有N个数。第二行为要去重的N个正整数。

Output

对于每组数据,输出一行,为去重后剩下的数字,数字之间用一个空格隔开。

Sample Input

2111 2 18 3 3 19 2 3 6 5 461 2 3 4 5 6

Sample Output

1 2 18 3 19 6 5 41 2 3 4 5 6

HINT

对于30%的数据,1 <= N <= 100,给出的数不大于100,均为非负整数;
对于50%的数据,1 <= N <= 10000,给出的数不大于10000,均为非负整数;
对于100%的数据,1 <= N <= 50000,给出的数在32位有符号整数范围内。

提示:
由于数据量很大,使用C++的同学请使用scanf和printf来进行输入输出操作,以免浪费不必要的时间。

#include<stdio.h>   
#include<string.h> 
#include<algorithm>  
using namespace std;  
int a[60000],b[60000],c[60000],k,n,m,l;  
bool v[60000];    
int find(int x)  
{  
    int st=1,ed=k,middle;   
    while(st<ed)  
    {  
        middle=(st+ed)/2;  
        if(x==c[middle])
		return middle;  
        if(ed-st==1)
		return ed;  
        if(x<c[middle])  
            ed=middle;  
        else 
			st=middle;  
    }  
}     
int main()  
{        
    scanf("%d",&m);  
    while(m--)  
    {  
        memset(v,true,sizeof(v));  
        scanf("%d",&n);  
        for(int i=1;i<=n;i++ )  
        {  
            scanf("%d",&a[i]);  
            b[i]=a[i];  
        }  
        sort(b+1,b+n+1);             
        c[1]=b[1];k=1;  
        for(int i=2;i<=n;i++ )  
            if( b[i]>b[i-1] )  
                c[++k]=b[i];                     
        l=find(a[1]);  
        v[l]=false;  
        printf("%d",a[1]);  
        for(int i=2;i<=n;i++ )  
        {  
            l=find(a[i]);  
            if(v[l]!=0)  
            {  
                v[l]=false;  
                printf(" %d",a[i]);  
            }  
        }  
        printf("\n");
    }   
} 


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值