2019牛客寒假算法基础集训营2 A处女座的签到题(STL)

题目链接
思路

精度用long long或者long double就可以解决,此题卡了sort,需要O(n)复杂度求第k大。
用long long 是因为面积公式除了/2都是整数,说明带小数只可能是0.5,特判即可

看群友讲到nth_element函数,搞了会一直错。才发现网上的第k “大” 我不是一个概念???
使第k个元素前面都比他小,后面比他大,这尼玛竟然是第k大。
这个函数也可以重载(重载记得开long long),重载成大的放前面。(应该还能给结构体之类的使用,待会儿自行试试)
具体见代码

代码
#include <bits/stdc++.h>
using namespace std;

#define ll long long

ll n, k, tot, x[105], y[105], ans[1000000];

bool cmp(ll i, ll j){return i>j;} // 重载记得也要ll不然会wa

int main()
{
    ll t;
    scanf("%lld",&t);
    while(t--)
    {
        scanf("%lld%lld",&n,&k);
        tot = 0;
        for(ll i = 0; i < n; ++i) scanf("%lld%lld",&x[i],&y[i]);
        for(ll a = 0; a < n; ++a)
            for(ll b = a+1; b < n; ++b)
                for(ll c = b+1; c < n; ++c)
                {
                    ll tmp =abs((x[a]*y[b] + x[b]*y[c] + x[c]*y[a] - x[a]*y[c] - x[b]*y[a] - x[c]*y[b]));
                    if(tmp) ans[tot++] = tmp;
                }
        nth_element(ans,ans+k-1,ans+tot,cmp);
        printf("%lld.",ans[k-1]/2);
        if(ans[k-1]%2) printf("50\n");
        else printf("00\n");
        /*
        nth_element(ans,ans+tot-k,ans+tot);
        printf("%lld.",ans[tot-k]/2);
        if(ans[tot-k]%2) printf("50\n");
        else printf("00\n");
        */
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值