• ACM-ICPC 2018 徐州赛区网络预赛 G题


    题目链接:

    https://nanti.jisuanke.com/t/31459

    具体思路:

    先顺序输入,然后回溯,假设已经加入了n个点,那么在加入的同时,首先看一下原先x轴上已经有过的点,找到第一个最接近第n个点并且小于第n个点的坐标,y轴同理。如果没有找到,比如说第一个,那么他减去的就是0.然后再就是代码,如果用数组存储的话,每进入一个点都需要对原来的数组进行重新排序,然后再去查找所需的值,这样会超时。可以用set存储,每进入一个数都会进行重新排序,然后存储完之后,再对set进行二分查找,找到第一个大于等于第n个点的坐标,然后这个点的前一个就是所需的点。

    #include<bits/stdc++.h>
    using namespace std;
    # define maxn 50000+10
    # define inf 0x3f3f3f3f
    # define ll long long
    ll x[maxn],y[maxn];
    ll n;
    ll cal(ll a[])
    {
        ll ans=0;
        set<int >s;
        set<int>::iterator iter;
        for(int i=n; i>=1; i--)
        {
            iter =s.lower_bound(a[i]);
            if(iter==s.begin())ans+=a[i];
            else
            {
                iter--;
                ans+=a[i]-(*iter);
            }
            s.insert(a[i]);
        }
        return ans;
    }
    int main()
    {
        scanf("%lld",&n);
        for(int i=1; i<=n; i++)
        {
            scanf("%lld%lld",&x[i],&y[i]);
        }
        ll t=cal(x)+cal(y);
        printf("%lld",t);
        return 0;
    }
    
  • 相关阅读:
    SpringMVC---RequestMapping注解类的使用方法
    SpringMVC---简单登录例子
    SpringMVC---简介
    MyBatis---动态SQL
    Hive基本操作
    hive初识
    scala编码规范
    Spark2.x 与 Spark1.x 关系
    spark idea项目打jar包的两种方式
    SparkStreaming 对Window的reduce的方法解析(转载)
  • 原文地址:https://www.cnblogs.com/letlifestop/p/10262918.html
Copyright © 2020-2023  润新知