zoukankan      html  css  js  c++  java
  • BZOJ2761 不重复的数字 【treap】

    2761: [JLOI2011]不重复数字

    Time Limit: 10 Sec  Memory Limit: 128 MB
    Submit: 5517  Solved: 2087
    [Submit][Status][Discuss]

    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

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

    Sample Output

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

    HINT

    对于30%的数据,1 <= N <= 100,给出的数不大于100,均为非负整数;


    对于50%的数据,1 <= N <= 10000,给出的数不大于10000,均为非负整数;


    对于100%的数据,1 <= N <= 50000,给出的数在32位有符号整数范围内。


    提示:


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


    本题的初衷应该是哈希,但哈希写的少,看见黄学长的treap如此简短,就试着写了一个平衡树

    一开始写splay,TLE【splay常数真的大= =,每次我用都超时】

    还是学学treap吧。。


    #include<iostream>
    #include<cstdio>
    #include<cstdlib>
    #include<cstring>
    #include<algorithm>
    #define LL long long int
    #define REP(i,n) for (int i = 1; i <= (n); i++)
    #define isr(u) (e[e[u].f].ch[1] == u)
    using namespace std;
    const int maxn = 50005,maxm = 100005,INF = 1000000000;
    inline int read(){
    	int out = 0,flag = 1;char c = getchar();
    	while (c < 48 || c > 57) {if (c == '-') flag = -1; c = getchar();}
    	while (c >= 48 && c <= 57) {out = out * 10 + c - 48; c = getchar();}
    	return out * flag;
    }
    int rt = 0,siz = 0,flag;
    struct node{int v,rnd,ls,rs;}e[maxn];
    inline void rturn(int& k){int t = e[k].ls;e[k].ls = e[t].rs;e[t].rs = k;k = t;}
    inline void lturn(int& k){int t = e[k].rs;e[k].rs = e[t].ls;e[t].ls = k;k = t;}
    inline void insert(int& k,int v){
    	if (!k) {e[k = ++siz].v = v; e[k].rnd = rand(); e[k].ls = e[k].rs = 0;}
    	else if (e[k].v == v) flag = false;
    	else if (e[k].v > v) {insert(e[k].ls,v); if (e[e[k].ls].rnd > e[k].rnd) rturn(k);}
    	else {insert(e[k].rs,v); if (e[e[k].rs].rnd > e[k].rnd) lturn(k);}
    }
    int main()
    {
    	int T = read(),N,v;
    	while (T--){
    		rt = siz = 0;
    		N = read(); v = read(); insert(rt,v);
    		printf("%d",v);
    		for (int i = 2; i <= N; i++){
    			v = read(); flag = true;
    			insert(rt,v);
    			if (flag) printf(" %d",v);
    		}
    		printf("
    ");
    	}
    	return 0;
    }
    



  • 相关阅读:
    典型页面布局
    网站表单输入框去除浏览器默认样式
    时间格式问题
    经典算法
    css自动换行
    git pull报“unable to update local ref”解决方案
    MYSQL数据插入和更新的语法
    正则表达式去除连续重复的字符
    linux保存住github的账号和密码
    php动态获取常量
  • 原文地址:https://www.cnblogs.com/Mychael/p/8282814.html
Copyright © 2011-2022 走看看