Kevin 正在一个社区中开发他的专业网络。不幸的是,他是个外地人,还不认识社区中的任何人。但是他可以与 N 个人建立朋友关系 。

然而,社区里没几个人想与一个外地人交朋友。Kevin 想交朋友的 N 个人都有类似但不同的与外地人交友的准则。在 Kevin 已经直接认识了社区中的 Ai 个人后,第 i 个人就愿意与 Kevin 交朋友了,否则 Kevin 就要付出 Bi 的代价与他成为朋友。

你的任务是,使 Kevin 与这 N 个人都交上朋友,并且最小化他付出的代价。

第一行包含整数 N。接下来的 N 行每行包含两个整数 Ai 和 Bi。

输出一行一个整数表示 Kevin 付出的最小代价。

题解

首先把所有的人按Ai排序的话,这N个人会形成一条折线,

如果一个一个人地解决掉(以强大的人脉折服他或收买他),那你的人脉的增长会成一条直线,

那么一个人 i 若在这个序列的位置为 i' ,且 i' > Ai,则解决这个人是不用花钱的,

这就很像一道叫 “不守交规”的贪心基础题,

描述

近些年来,生活水平越来越好,私家车也成了很多家庭必备之物。但某些司机总是不守交规,罚单也是接踵而至。

有一位不遵守交规的司机,在同一天收到了n条违章罚单短信(1≤n≤100),每条罚单短信中有两个内容,一:交罚款的最后剩余时间ti;二:过期未交的滞纳金mi(1≤ti,mi≤1000),假设不管过期多少天,滞纳金数量不会改变,而且,这位司机很忙,每天最多只能处理一张罚单,那么,这位司机应该按怎样的处理违章短信的顺序,才能使滞纳金总和最少?

输入共n+1行

第1行:收到短信数n

后n行:每行分别两个数,最后期限ti和过期滞纳金mi,用空格隔开

输出

最少的滞纳金总和

样例输入

4

1 50

1 100

2 60

3 60

样例输出

50

解题思路

首先我们能够想到按照滞纳金的从大到小进行排序,但是真的是按照时间顺序处理这些从大到小的滞纳金吗?其实不是的,我们最优贪心思想应该是按照滞纳金的按照滞纳金的从大到小进行排序,越大的滞纳金能够拖到最后一天处理就最后一天处理;如果最后一天已经处理过以其他的滞纳金,则就从这一天倒着往前开始找,看看那一天没有处理过滞纳金,就在这一天处理该滞纳金;如果没有找到,则说明一定要缴纳此滞纳金。

——————————————————————————————————————————

原文链接:https://blog.csdn.net/qq_37220238/article/details/80013402

一样的思路,把人按Bi从大到小排,然后在 [Ai + 1,n]中找一个最靠左的位置放,位置被占完了就只能拿钱买他。

只不过得加一个log优化

#include<cstdio>
#include<cstring>
#include<vector>
#include<stack>
#include<queue>
#include<algorithm>
#include<map>
#include<cmath>
#include<iostream>
#define LL long long
using namespace std;
int read() {
int f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s == '-')f = -1;s = getchar();}
while(s >= '0' && s <= '9') {x = x * 10 + s - '0';s = getchar();}
return x * f;
}
LL max(LL a,LL b) {
return a > b ? a : b;
}
struct it{
LL nm,co;
}a[200005];
bool operator < (it a,it b) {
if(a.co != b.co) return a.co > b.co;
else return a.nm < b.nm;
}
LL n,m,i,j,k,s,o;
int tre[800005];
int aa[200005];
int bing(int x,int y) {
if(aa[x] < aa[y]) return x;
if(aa[x] > aa[y]) return y;
return x < y ? x : y;
}
void maketree(int n) {
m = 1;
while(m < n + 2) m <<= 1;
}
void F5(int x) {
int s = m + x;
tre[s] = x;
s /= 2;
while(s) {
tre[s] = bing(tre[s * 2],tre[s * 2 + 1]);
s /= 2;
}
return ;
}
int findt(int l,int r) {
int s = m + l - 1,t = m + r + 1;
int ans = 0;
while(s || t) {
if(s / 2 != t / 2) {
if(s % 2 == 0) {
ans = bing(ans,tre[s + 1]);
}
if(t % 2) {
ans = bing(ans,tre[t - 1]);
}
}
else break;
s /= 2;t /= 2;
}
return ans;
}
int main() {
n = read();
maketree(n + 1);
for(int i = 1;i <= n;i ++) {
a[i].nm = read();
a[i].co = read();
}
sort(a + 1,a + 1 + n);a[0].co = 0x7f7f7f7f;
for(int i = 1;i <= n + 1;i ++) F5(i);aa[0] = 2;
LL ans = 0;
for(int i = 1;i <= n;i ++) {
int j = a[i].nm + 1,k;
// cout<<j<<endl;
if((k = findt(j,n + 1)) <= n) {
aa[k] = 1;
F5(k);
}
else ans += a[i].co;
}
printf("%lld\n",ans);
return 0;
}

「CCO 2017」专业网络的更多相关文章

  1. 「THUSCH 2017」大魔法师 解题报告

    「THUSCH 2017」大魔法师 狗体面太长,帖链接了 思路,维护一个\(1\times 4\)的答案向量表示\(A,B,C,len\),最后一个表示线段树上区间长度,然后每次的操作都有一个转移矩阵 ...

  2. 「THUWC 2017」随机二分图

    「THUWC 2017」随机二分图 解题思路 : 首先有一个 \(40pts\) 的做法: 前 \(20pts\) 暴力枚举最终的匹配是怎样的,check一下计算方案数,后 \(20pts\) 令 \ ...

  3. LOJ 2288「THUWC 2017」大葱的神力

    LOJ 2288「THUWC 2017」大葱的神力 Link Solution 比较水的提交答案题了吧 第一个点爆搜 第二个点爆搜+剪枝,我的剪枝就是先算出 \(mx[i]\) 表示选取第 \(i \ ...

  4. 「NOIP 2017」列队

    题目大意:给定一个 $n times m$ 的方阵,初始时第 $i$ 行第 $j$ 列的人的编号为 $(i-1) times m + j$,$q$ 次给出 $x,y$,让第 $x$ 行 $y$ 列的人 ...

  5. @loj - 2977@ 「THUSCH 2017」巧克力

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 「人生就像一盒巧克力,你永远不知道吃到的下一块是什么味道.」 明 ...

  6. 「LOJ 2289」「THUWC 2017」在美妙的数学王国中畅游——LCT&泰勒展开

    题目大意: 传送门 给一个动态树,每个节点上维护一个函数为$f(x)=sin(ax+b)$.$f(x)=e^{ax+b}$.$f(x)=ax+b$中的一个. 支持删边连边,修改节点上函数的操作. 每次 ...

  7. LOJ #2978「THUSCH 2017」杜老师

    听说LOJ传了THUSC题赶紧上去看一波 随便点了一题都不会做想了好久才会写暴力爆了一发过了... LOJ #2978 题意 $ T$次询问,每次询问$ L,R$,问有多少种选取区间中数的方案使得选出 ...

  8. LOJ 2409「THUPC 2017」小 L 的计算题 / Sum

    思路 和玩游戏一题类似 定义\(A_k(x)=\sum_{i=0}^\infty a_k^ix^i=\frac{1}{1-a_kx}\) 用\(\ln 'x\)代替\(\frac{1}{x}\), 所 ...

  9. 「THUWC 2017」在美妙的数学王国中畅游

    这个题目很明显在暗示你要用泰勒展开. 直接套上去泰勒展开的式子,精度的话保留12项左右即可. 分别维护每一项的和,可能比较难写吧. 然后强行套一个LCT就没了.

随机推荐

  1. .Net CLR GC动态获取函数头地址,C++的骚操作(慎入)

    前言: 太懒了,从没有在这里正儿八经的写过文章.看到一些人的高产,真是惭愧.决定稍微变得不那么懒.如有疏漏,请指正. .net的GC都谈的很多了,本篇主要是剑走偏锋,聊聊一些个人认为较为核心的细节方面 ...

  2. python之多进程and多线程

    图文来自互联网 一.什么是进程和线程 (https://jq.qq.com/?_wv=1027&k=rX9CWKg4) 进程是分配资源的最小单位,线程是系统调度的最小单位. 当应用程序运行时最 ...

  3. map集合中对应key的value为null处理办法

    问题: Map集合中对应key的value为null,但是现在需要将这个value转为Integer类型,这个value如果不是null,那么get到的是long类型或者是Bigdecimal类型 处 ...

  4. CMU15445 (Fall 2019) 之 Project#1 - Buffer Pool 详解

    前言 这个实验有两个任务:时钟替换算法和缓冲池管理器,分别对应 ClockReplacer 和 BufferPoolManager 类,BufferPoolManager 会用 ClockReplac ...

  5. jvm jni 及 pvm pybind11 大批量数据传输及优化

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明   本文作为本人csdn blog的主站的备份.(Bl ...

  6. 洛谷P2709 小B的询问 莫队做法

    题干 这个是用来学莫队的例题,洛谷详解 需要注意的一点,一定要分块!不然会慢很多(直接TLE) 其中分块只在排序的时候要用,并且是给问题右端点分块 再就是注意add与del函数里的操作,增加数量不提, ...

  7. 优化对称加密的 shell 脚本

    前言 之前一篇文章<shell 脚本实现文件对称加密>中,讲述了如何用 shell 脚本实现对称加密. 之后写管理密码脚本时,发觉该脚本的处理速度非常慢,而其原因就在 shell 的处理命 ...

  8. led跑马灯多种方法(移位法,位拼接法,调用模块法,位移及位拼接语法,testbench的理解,源文件的存储路径,计数器的个数,调用模块的方式)

    跟着教程写了几种方法,才发现自己写的虽然能实现,但比较繁琐.教程有三种方法: 1.移位法,每次左移一位,相比我自己写的,优点是不用把每一种情况都写出来.但是需要考虑左移到最后一位时需要自己再写个赋值语 ...

  9. 再见Docker!Containerd安装与使用

    Containerd 的技术方向和目标 简洁的基于 gRPC 的 API 和 client library 完整的 OCI 支持(runtime 和 image spec) 同时具备稳定性和高性能的定 ...

  10. 年中盘点 | 2022年,PaaS 再升级

    作者丨刘世民(Sammy Liu)全文共7741个字,预计阅读需要15分钟 过去十五年,是云计算从无到有突飞猛进的十五年.PaaS作为云计算的重要组成部分,在伴随着云计算高速发展的同时,在云计算产业链 ...