2023NOIP A层联测20 T3 点餐
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 点餐的更多相关文章
- 汕头市队赛SRM 20 T3 灵魂觉醒
		
背景 自从芽衣.布洛妮娅相继灵魂觉醒之后,琪亚娜坐不住了.自己可是第一个入驻休伯利安号的啊!于是她打算去找德丽莎帮忙,为她安排了灵魂觉醒的相关课程. 第一天,第一节课. “实现灵魂觉醒之前,你需要先将 ...
 - 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 里遇到的 ...
 - [转]oracle分页用两层循环还是三层循环?
		
select t2.* from --两层嵌套 (select t.* , rownum as row_numfrom t where rownum <=20) t2 where t2.row_ ...
 - Python数据分析之Pandas操作大全
		
从头到尾都是手码的,文中的所有示例也都是在Pycharm中运行过的,自己整理笔记的最大好处在于可以按照自己的思路来构建矿建,等到将来在需要的时候能够以最快的速度看懂并应用=_= 注:为方便表述,本章设 ...
 - Block解析(iOS)
		
1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...
 - 很强大的HTML+CSS+JS面试题(附带答案)
		
一.单项选择(165题) 1.HTML是什么意思? A)高级文本语言 B)超文本标记语言 C)扩展标记语言 D)图形化标记语言 2.浏览器针对于HTML文档起到了什么作用? A)浏览器用于创建HTML ...
 - MySQL Nested-Loop Join算法学习
		
不知不觉的玩了两年多的MySQL,发现很多人都说MySQL对比Oracle来说,优化器做的比较差,其实某种程度上来说确实是这样,但是毕竟MySQL才到5.7版本,Oracle都已经发展到12c了,今天 ...
 - sprint one
		
产品backlog Id Name Imp Est How to demo 1 各个角色账号登录功能 30 20 建立数据库,数据库中存储一些角色的初始账号以便测试,输入账号密码,系统在数据库中查找账 ...
 - block的解析
		
1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...
 - Objective-C中的Block
		
1.相关概念 在这篇笔记开始之前,我们需要对以下概念有所了解. 1.1 操作系统中的栈和堆 注:这里所说的堆和栈与数据结构中的堆和栈不是一回事. 我们先来看看一个由C/C++/OBJC编译的程序占用内 ...
 
随机推荐
- QTreeWidget折叠子项(折叠当前项的所有子项)
			
QTreeWidget折叠子项(折叠当前项的所有子项) 本文仅供本人知识总结使用,所以内容会比较浅显,不喜勿喷. 文章目录 QTreeWidget折叠子项(折叠当前项的所有子项) 一.仅折叠子项 二. ...
 - 以Top-Down思维去解决问题——递归
			
目录 递归的基础 递归的底层实现(不是重点) 递归的应用场景 编程中 两种解决问题的思维 自下而上(Bottom-Up) 自上而下(Top-Down) 自上而下的思考过程--求和案例 台阶问题 案例 ...
 - html  跳转到新的网址
			
更新window.location.href后面的值即可 文件名为 index.html <!DOCTYPE html> <html> <head> <met ...
 - Servlet——Request对象-请求数据&请求参数
			
Request 继承体系 1.Tomcat需要解析请求数据,封装为request对象,并且创建request对象传递到service方法中 2.使用request对象,查阅javaEE ...
 - 在Linux 中使用 pidstat 命令监控进程性能
			
一.安装 pidstat 命令 检查系统是否已经安装了 pidstat 打开终端,输入以下命令检查是否已经安装了 pidstat: pidstat -V 如果显示版本信息,说明已经安装,可以跳过安装步 ...
 - 28. 找出字符串中第一个匹配项的下标 Golang实现
			
题目描述: 给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始).如果 needle 不是 hay ...
 - 未来“数”于你 |  墨天轮携手 Vertica 发布技术文章征集令,双重大奖蓄势待“发”
			
作为新一代数据分析平台,Vertica凭借高性能.高可用性以及混合模式部署的底层架构等特点,为国内电信.金融行业提供了较多的整体解决方案. 今天,Vertica 限时开放体验,同时,MacBook P ...
 - Android复习(一)基础知识
			
1. 现在可以使用 Kotlin.Java 和 C++ 语言编写 Android 应用 2.Android四大组件依然坚挺,这是基础并且没有改变的迹象 Activity 服务 广播接收器 内容提供程序 ...
 - fastjson序列化导致prometheus返回监控数据格式错乱
			
在springboot 中集成prometheus的监控时遇见问题. 因为项目里在StaticResourceConfig配置了fastjson 序列化,导致prometheus接口返回数据被转化为j ...
 - DIY Matter Bridge 和智能锁简单联动的实践
			
一. 写在前面 在之前的博客文章 <基于乐鑫 ESP32-C3 的 Matter Light 实践>中,我们利用乐鑫的硬件和 SDK 方案实现了简单的 Light 例程,并对 Matter ...