2023NOIP A层联测20 点餐

题目很好,可惜考试没想到。

思路

可以按照 \(b\) 从小到大排序,固定选择个数 \(k\),枚举选择的盘子 \(x\) 的 \(b\) 最大,最优解肯定是贪心的在前 \(x-1\) 个盘子里选择 \(k-1\) 个最小的,使用权值主席树可以在 \(O(\log_2n)\) 的时间内求解。

我们令 \(f(k)\) 表示 \(k\) 的最优解决策点 \(x\)。设 \(w(k,x)\) 当 \(k\) 的决策点为 \(x\) 时的最优答案。对于两个不同的决策 \(x,y\ (x<y)\),若有 \(w(k,x)>w(k,y)\) ,那么 \(k\) 增大后 \(x\) 可以新选的 \(a\) 值一定严格包含在 \(y\) 可以新选的 \(a\) 值以内,即 \(w(k',x)\geq w(k',y)\) 对于 \(k\leq k'\leq n\) 恒成立,所以有 \(f(k)\leq f(k')\ (k\leq k')\)。由此可得 \(f(1)\leq f(2) \leq f(3) \leq \cdots \leq f(n)\)。决策点具有单调性,可以分治求解(每次选一个区间的中点暴力求,将终点分为两半继续求,具体实现见代码)。

由于分治每一层最多跑 \(O(n)\),有 \(O(\log_2 n)\) 层,所以要求 \(O(n\log_2 n)\) 次 \(w(k,i)\),求一次 \(w(k,i)\) 要 \(O(\log_2 n)\),时间复杂度为 \(O(n\log_2^2 n)\)。

CODE

#include<bits/stdc++.h>
using namespace std; #define inf 2e9
#define int long long const int maxn=2e5+5; struct node
{
int ls,rs,sz,sum;
}tree[maxn*50];
struct node1
{
int a,b;
}food[maxn]; int n,tot;
int ans[maxn],rt[maxn]; bool cmp(node1 a,node1 b){return a.b<b.b;} void insert(int &p,int x,int l,int r)
{
tree[++tot]=tree[p];
p=tot;
if(l==r)
{
tree[p].sum+=x-1;
tree[p].sz++;
return ;
} int mid=l+r>>1;
if(x<=mid) insert(tree[p].ls,x,l,mid);
else insert(tree[p].rs,x,mid+1,r); tree[p].sum=tree[ tree[p].ls ].sum+tree[ tree[p].rs ].sum;
tree[p].sz=tree[ tree[p].ls ].sz+tree[ tree[p].rs ].sz;
}
int getsum(int p,int l,int r,int k)
{
if(l==r) return (l-1)*k;
int mid=l+r>>1;
if(tree[tree[p].ls].sz>=k) return getsum(tree[p].ls,l,mid,k);
else return getsum(tree[p].rs,mid+1,r,k-tree[tree[p].ls].sz)+tree[tree[p].ls].sum;
} void solve(int l,int r,int lp,int rp)//[l,r] 的个数区间,对于 [lp,rp] 决策区间的点
{
if(r<l) return ;
int mid=l+r>>1,pos=0;
for(int i=max(lp,mid);i<=rp;i++)
{
int now=food[i].b+food[i].a+getsum(rt[i-1],1,inf,mid-1);//求 w(mid,i)
if(ans[mid]>=now)
{
ans[mid]=now;
pos=i;
}
}
solve(l,mid-1,lp,pos);//分析 f 的分布可以得出
solve(mid+1,r,pos,rp);
} signed main()
{
scanf("%lld",&n);
for(int i=1;i<=n;i++) scanf("%lld%lld",&food[i].a,&food[i].b); sort(food+1,food+n+1,cmp);
for(int i=1;i<=n;i++)
insert(rt[i]=rt[i-1],food[i].a+1,1,inf);
memset(ans,0x5f,sizeof(ans));
solve(1,n,1,n); for(int i=1;i<=n;i++) printf("%lld\n",ans[i]);
}

2023NOIP A层联测20 T3 点餐的更多相关文章

  1. 汕头市队赛SRM 20 T3 灵魂觉醒

    背景 自从芽衣.布洛妮娅相继灵魂觉醒之后,琪亚娜坐不住了.自己可是第一个入驻休伯利安号的啊!于是她打算去找德丽莎帮忙,为她安排了灵魂觉醒的相关课程. 第一天,第一节课. “实现灵魂觉醒之前,你需要先将 ...

  2. CEOI 2019 Day2 T2 魔法树 Magic Tree (LOJ#3166、CF1993B、and JOI2021 3.20 T3) (启发式合并平衡树,线段树合并)

    前言 已经是第三次遇到原题. 第一次是在 J O I 2021 S p r i n g C a m p \rm JOI2021~Spring~Camp JOI2021 Spring Camp 里遇到的 ...

  3. [转]oracle分页用两层循环还是三层循环?

    select t2.* from --两层嵌套 (select t.* , rownum as row_numfrom t where rownum <=20) t2 where t2.row_ ...

  4. Python数据分析之Pandas操作大全

    从头到尾都是手码的,文中的所有示例也都是在Pycharm中运行过的,自己整理笔记的最大好处在于可以按照自己的思路来构建矿建,等到将来在需要的时候能够以最快的速度看懂并应用=_= 注:为方便表述,本章设 ...

  5. Block解析(iOS)

    1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...

  6. 很强大的HTML+CSS+JS面试题(附带答案)

    一.单项选择(165题) 1.HTML是什么意思? A)高级文本语言 B)超文本标记语言 C)扩展标记语言 D)图形化标记语言 2.浏览器针对于HTML文档起到了什么作用? A)浏览器用于创建HTML ...

  7. MySQL Nested-Loop Join算法学习

    不知不觉的玩了两年多的MySQL,发现很多人都说MySQL对比Oracle来说,优化器做的比较差,其实某种程度上来说确实是这样,但是毕竟MySQL才到5.7版本,Oracle都已经发展到12c了,今天 ...

  8. sprint one

    产品backlog Id Name Imp Est How to demo 1 各个角色账号登录功能 30 20 建立数据库,数据库中存储一些角色的初始账号以便测试,输入账号密码,系统在数据库中查找账 ...

  9. block的解析

    1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...

  10. Objective-C中的Block

    1.相关概念 在这篇笔记开始之前,我们需要对以下概念有所了解. 1.1 操作系统中的栈和堆 注:这里所说的堆和栈与数据结构中的堆和栈不是一回事. 我们先来看看一个由C/C++/OBJC编译的程序占用内 ...

随机推荐

  1. kube-flannel.yml

    --- apiVersion: policy/v1beta1 kind: PodSecurityPolicy metadata: name: psp.flannel.unprivileged anno ...

  2. CSS学习(一)CSS和文档

    应用样式的三种方式 外部样式表(link.@import) 嵌入式样式表(<style></style>) 行内样式 (html元素的属性为style的值作为样式) CSS的空 ...

  3. 【图文安装教程】在docker中安装kibana

    在上一篇中,我们已经在docker里面安装了ES. kibana可以给我们提供一个elasticsearch的可视化界面,便于我们学习. 所以,本篇咱们就在docker里面安装kibana图文教程: ...

  4. Blockchain A-Z™: Learn How To Build Your First Blockchain

    单纯从技术角度了解blockthain. Module 1, Blockchain 特点: 分布式的,不可篡改的,p2p的 网络.存储在每个node上保存一份,这就是个基于网络的RAID 1 啊,感觉 ...

  5. HTML – script async defer

    参考 Youtube – #3 JavaScript Loading Strategies (async and defer) | JavaScript Full Tutorial no async ...

  6. 手撸MQ消息队列——循环数组

    队列是咱们开发中经常使用到的一种数据结构,它与栈的结构类似.然而栈是后进先出,而队列是先进先出,说的专业一点就是FIFO.在生活中到处都可以找到队列的,最常见的就是排队,吃饭排队,上地铁排队,其他就不 ...

  7. OAuth2.0授权-gitee授权码模式

    OAuth2.0授权验证-gitee授权码模式 本文主要介绍如何笔者自己是如何使用gitee提供的OAuth2.0协议完成授权验证并登录到自己的系统,完整模式如图 1.创建应用 打开gitee个人中心 ...

  8. QT6框架WebEngine模块之WebEngine总体介绍以及WebEngine能做什么?

    QT6框架WebEngine模块之WebEngine总体介绍以及WebEngine能做什么? 简介 本文简略介绍QT6框架WebEngine模块之WebEngine总体介绍以及WebEngine能做什 ...

  9. MySQL linux下安装,配置,免密登录与基本认识

    目录 MySQL卸载 环境 查看是否已安装MySQL 卸载mysql服务 查看是否卸载干净 MySQL安装 查看linux版本 选择MySQL版本 获取mysql官方yum源 rpm安装mysql官方 ...

  10. Qt中当程序结束时线程的退出

    在Qt程序结束时应该如何退出正在运行的任务子线程? 因个人经验和能力有限,本文仅供参考,有错误或者考虑不完善的地方请各位批评指正. 一.正常情况下如何创建和退出线程 1.继承QThread,重写run ...