• P1168 中位数


    P1168 中位数

    一个大根堆,一个小根堆。胡乱搞搞就可以了,根据中位数的计算方法。

    #include<cstdio> 
    #include<iostream>
    #include<algorithm>
    struct Min_heap
    {
        int tail;
        int data[100010];
        int top()
        {
            return data[1];
        }
        void swap(int &a,int &b)
        {
            int c=a;
            a=b;
            b=c;
            return ;
        }
        void insert(int value)
        {
            data[++tail]=value;
            int pos=tail;
            while(pos&&data[pos>>1]>data[pos])
            {
                swap(data[pos>>1],data[pos]);
                pos>>=1;
            }
            return ;
        }
        void del()
        {
            swap(data[1],data[tail]);
            tail--;
            int pos=1,pass;
            while(pos<=tail)
            {
                pass=pos;
                if(data[pass]>data[pos<<1]&&(pos<<1)<=tail)
                    pass=pos<<1;
                if(data[pass]>data[pos<<1|1]&&(pos<<1|1)<=tail)
                    pass=pos<<1|1;
                if(pass==pos)
                    break;
                swap(data[pass],data[pos]);
                pos=pass;
            }
            return ;
        }
    };
    struct Max_heap
    {
        int tail;
        int data[100010];
        int top()
        {
            return data[1];
        }
        void swap(int &a,int &b)
        {
            int c=a;
            a=b;
            b=c;
            return ;
        }
        void insert(int value)
        {
            data[++tail]=value;
            int pos=tail;
            while(pos&&data[pos>>1]<data[pos]&&pos>>1)
            {
                swap(data[pos>>1],data[pos]);
                pos>>=1;
            }
            return ;
        }
        void del()
        {
            swap(data[1],data[tail]);
            tail--;
            int pos=1,pass;
            while(pos<=tail)
            {
                pass=pos;
                if(data[pass]<data[pos<<1]&&(pos<<1)<=tail)
                    pass=pos<<1;
                if(data[pass]<data[pos<<1|1]&&(pos<<1|1)<=tail)
                    pass=pos<<1|1;
                if(pass==pos)
                    break;
                swap(data[pass],data[pos]);
                pos=pass;
            }
            return ;
        }
    };
    Min_heap h1;
    Max_heap h2;
    int main()
    {
        int n;
        scanf("%d",&n);
        int a;
        for(int i=1;i<=n;i++)
        {
            scanf("%d",&a);
            /*h1.insert(a);
            if(i%2)
            {
                h2.insert(h1.top());
                h1.del();
                printf("%d ",h2.top());
            }*/
            /*if(h1.top()>a)
                h2.insert(a);
            else*/
            h1.insert(a);
            if(h1.tail>h2.tail-1)
                while(h1.tail>h2.tail-1)
                {
                    h2.insert(h1.top());
                    h1.del();
                }
            if(h1.tail<h2.tail-1)
                while(h1.tail<h2.tail-1)
                {
                    h1.insert(h2.top());
                    h2.del();
                }
            if(i%2)
                printf("%d
    ",h2.top());
        }
        return 0;
    }
    
  • 相关阅读:
    求质数与因式分解
    利用工具解题
    我的学生信息管理系统总结
    JSP简单练习-页面重定向
    CSS学习(三)—相对定位与绝对定位
    java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
    AVL平衡树的插入例程
    SAE搭建WordPress教程 免费建WordPress博客站
    MPMoviePlayerViewController和MPMoviePlayerController的使用
    Android日志输出工具类
  • 原文地址:https://www.cnblogs.com/Lance1ot/p/8762065.html
Copyright © 2020-2023  润新知