题目链接

Description

一辆火车依次经过 \(n\) 个车站,顺序是 \(1, 2, 3, ..., n - 1, n\)。给定 \(A_{i, j}\) 表示从 \(i\) 站上车,\(j\) 站下车的个数。

有 \(K\) 次在每站操作后的检票机会,问最多能检票的多少不同的人。

Solution

这相当于给你 \(\dfrac{n^2}{2}\) 条线段(对于 \(A_{i, j}\) 而言对应的线段是 \([i, j - 1]\),因为选的点是在那站后,下车的就没了),每个线段有个权值,让你选择 \(K\) 个点,使得 \(K\) 个点所涉及的线段(重复的算一次)的权值和最大。

考虑 DP,用代表元计数法,考虑把每个线段的贡献记录在他那条线段上有的第一个点上。

状态设计

设 \(f_{i, j}\) 为前 \(i\) 个车站,已经检票了 \(j\) 次,并且在第 \(i\) 个车站后检票的最多人数

初始状态

\(f_{0, 0} = 0\),其余为负无穷(其实这里赋值与否没啥关系)。

状态转移

\(f_{i, j} = \max\{f_{k, j - 1} + val(k + 1, i)\}\)

其中 \(val(l, r)\) 表示在线段左端点在 \([l, r]\) 且右端点 $ \ge r$ 的线段个数,这个东西可以 \(O(N^3)\) 暴力预处理。

答案

\(ans = \max\{f[i][K]\}\)

时间复杂度

\(O(N^2K)\)

Tips

  • 大坑,可能造成贡献的点 $ < K$,这时候你就需要从剩下的站点中,选择一些字典序较小的来输出。

Code

#include <iostream>
#include <cstdio> using namespace std; const int N = 605, S = 55; int n, tot, K, a[N][N], pre[N][S], val[N][N], cnt[N], f[N][S]; bool vis[N]; void print(int i, int j) {
if (j == 0 || i == 0) return ;
print(pre[i][j], j - 1);
vis[i] = true;
++tot;
} int main() {
scanf("%d%d", &n, &K);
for (int i = 1; i <= n; i++) {
for (int j = i + 1; j <= n; j++) scanf("%d", &a[i][j]);
} for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++) cnt[j] = 0;
for (int j = i; j <= n; j++) {
for (int k = j + 1; k <= n; k++) cnt[k - 1] += a[j][k];
for (int k = n; k >= j; k--) val[i][j] += cnt[k];
}
} for (int i = 1; i <= n; i++) {
for (int j = 1; j <= K; j++) {
for (int k = 0; k < i; k++) {
if (f[k][j - 1] + val[k + 1][i] > f[i][j]) {
f[i][j] = f[k][j - 1] + val[k + 1][i];
pre[i][j] = k;
}
} }
} int ans = 0, p;
for (int i = 1; i <= n; i++) if (f[i][K] > ans) ans = f[i][K], p = i;
print(p, K);
for (int i = 1; i <= n; i++) {
if (vis[i]) printf("%d ", i);
else if (tot < K) tot++, printf("%d ", i);
}
return 0;
}

POI2009 KON-Ticket Inspector的更多相关文章

  1. bzoj 1133: [POI2009]Kon dp

    1133: [POI2009]Kon Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 242  Solved: 81[Submit][Status][D ...

  2. bzoj1133: [POI2009]Kon

    bzoj1133: [POI2009]Kon 链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1133 思路 f[i][k]表示前i个,选了k个 ...

  3. 解题:POI 2009 Ticket Inspector

    题面 看起来很水,然而不会DP的蒟蒻并不会做,PoPoqqq orz 设$f[i][j]$表示当前在第$i$个点和第$i+1$个点之间查票,已经查了$j$次的最大收益.然后就是那种很常见的枚举前一个结 ...

  4. [POI2009]Kon

    Description 火车沿途有N个车站,告诉你从每一站到每一站的人数,现在查票员只能查K次票,每次查票可以控制目前在车上的所有乘客的车票.求一个查票方案,使得控制的不同的乘客尽量多. (显然对同一 ...

  5. 洛谷 P3486 [POI2009]KON-Ticket Inspector

    P3486 [POI2009]KON-Ticket Inspector 题目描述 Byteasar works as a ticket inspector in a Byteotian Nationa ...

  6. [洛谷P3486]POI2009 KON-Ticket Inspector

    问题描述 Byteasar works as a ticket inspector in a Byteotian National Railways (BNR) express train that ...

  7. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  8. P3486 [POI2009]KON-Ticket Inspector

    啊!这题做的真是爽!除了DP这个方法是有提示的之外,这题居然没有题解,哈哈哈嘿嘿嘿.很自豪的说:全是我自己独立解出来的一道题,包括设计状态,推倒(☺)转移方程,最后记录路径. 好了,首先,我们发现这题 ...

  9. [POI2009]KON-Ticket Inspector(二维前缀和+DP)

    题意 有n个车站,现在有一辆火车从1到n驶过,给出aij代表从i站上车j站下车的人的个数.列车行驶过程中你有K次检票机会,所有当前在车上的人会被检票,问最多能检多少个不同的人的票 (n<=600 ...

随机推荐

  1. SpringBoot第十一集:整合Swagger3.0与RESTful接口整合返回值(2020最新最易懂)

    SpringBoot第十一集:整合Swagger3.0与RESTful接口整合返回值(2020最新最易懂) 一,整合Swagger3.0 随着Spring Boot.Spring Cloud等微服务的 ...

  2. springboot升级导致文件上传自动配置/tmp目录问题解决

    1,..\web\src\main\resources\spring\web-men-applicationContext.xml 保留原有的bean配置 <bean id="mult ...

  3. 3、Spring Boot日志

    1.日志框架 市面上的日志框架:JUL.JCL.Jboss-logging.logback.log4j.log4j2.slf4j.... 日志门面 (日志的抽象层) 日志实现 JCL(Jakarta ...

  4. Gulp自动化构建的基本使用

    Study Notes 本博主会持续更新各种前端的技术,如果各位道友喜欢,可以关注.收藏.点赞下本博主的文章. Gulp 用自动化构建工具增强你的工作流程! gulp 将开发流程中让人痛苦或耗时的任务 ...

  5. 痞子衡嵌入式:揭秘i.MXRT600的ISP模式下用J-Link连接后PC总是停在0x1c04a的原因(Debug Mailbox)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT600中的Debug Mailbox实现对JLink调试的影响. 事情缘起痞子衡的同事 - 喜欢打破砂锅问到底的Kerry小 ...

  6. 面试老被问LinkedList源码?看看阿里技术官是怎么深度剖析的吧!

    前言 LinkedList底层是基于双向链表,链表在内存中不是连续的,而是通过引用来关联所有的元素,所以链表的优点在于添加和删除元素比较快,因为只是移动指针,并且不需要判断是否需要扩容,缺点是查询和遍 ...

  7. Android呼吸灯添加

    平台:mtk 一.hal层入口    Lights.c (vendor\mediatek\proprietary\hardware\liblights)     char const*const RE ...

  8. 如何用ABBYY FineReader 识别表格

    ABBYY FineReader有着强大的OCR文字识别功能,不但可以将文件转换为文本文档或Word文档,也可以识别PDF文件或者图片上的表格,并且转换为Excel文件. 下面小编就使用ABBYY F ...

  9. 「LOJ 537」「LibreOJ NOIP Round #1」DNA 序列

    description NOIP 复赛之前,HSD 桑进行了一项研究,发现人某条染色体上的一段 DNA 序列中连续的\(k\)个碱基组成的碱基序列与做题的 AC 率有关!于是他想研究一下这种关系. 现 ...

  10. 01-01.单一职责原则(Single Responsibility)

    1.基本介绍 对于类来说的,就是一个类,应该只负责一项职责(一个类只管一件事). 如类A负责两个不同职责:职责1,职责2. 当职责1需求变更而改变A时,可能造成职责2执行错误,所以需要将类A的粒度分解 ...