POI2009 KON-Ticket Inspector
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的更多相关文章
- bzoj 1133: [POI2009]Kon dp
1133: [POI2009]Kon Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 242 Solved: 81[Submit][Status][D ...
- bzoj1133: [POI2009]Kon
bzoj1133: [POI2009]Kon 链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1133 思路 f[i][k]表示前i个,选了k个 ...
- 解题:POI 2009 Ticket Inspector
题面 看起来很水,然而不会DP的蒟蒻并不会做,PoPoqqq orz 设$f[i][j]$表示当前在第$i$个点和第$i+1$个点之间查票,已经查了$j$次的最大收益.然后就是那种很常见的枚举前一个结 ...
- [POI2009]Kon
Description 火车沿途有N个车站,告诉你从每一站到每一站的人数,现在查票员只能查K次票,每次查票可以控制目前在车上的所有乘客的车票.求一个查票方案,使得控制的不同的乘客尽量多. (显然对同一 ...
- 洛谷 P3486 [POI2009]KON-Ticket Inspector
P3486 [POI2009]KON-Ticket Inspector 题目描述 Byteasar works as a ticket inspector in a Byteotian Nationa ...
- [洛谷P3486]POI2009 KON-Ticket Inspector
问题描述 Byteasar works as a ticket inspector in a Byteotian National Railways (BNR) express train that ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- P3486 [POI2009]KON-Ticket Inspector
啊!这题做的真是爽!除了DP这个方法是有提示的之外,这题居然没有题解,哈哈哈嘿嘿嘿.很自豪的说:全是我自己独立解出来的一道题,包括设计状态,推倒(☺)转移方程,最后记录路径. 好了,首先,我们发现这题 ...
- [POI2009]KON-Ticket Inspector(二维前缀和+DP)
题意 有n个车站,现在有一辆火车从1到n驶过,给出aij代表从i站上车j站下车的人的个数.列车行驶过程中你有K次检票机会,所有当前在车上的人会被检票,问最多能检多少个不同的人的票 (n<=600 ...
随机推荐
- Freebsd10.2安装包升级pkg引起环境破坏的解决
前言 freebsd10.2环境在安装一个新软件包的时候提示升级pkg到1.10.1,然后点击了升级,然后整个pkg环境就无法使用了 记录 升级完了软件包以后第一个错误提示 FreeBSD: /usr ...
- 2018.1.22 js
1.JavaScrip运算符 [案例]a+=b 等价于 a=a+ba-=b 等价于 a=a-ba*=b 等价于 a=a*ba/=b 等价于 a=a/ba%=b 等价于 a%=b2.逻辑控制语句语法1: ...
- [LeetCode题解]86. 分隔链表 | 三指针 + 虚拟头节点
解题思路 三指针,一个指向前半部分待插入位置,一个指向后半部分待插入位置,最后一个从前往后遍历 代码 /** * Definition for singly-linked list. * public ...
- FL Studio音乐编曲入门教程
有很多小伙伴给我们留言说使用FL Studio20一段时间后,虽然对这款音乐编曲软件的功能有了一个了解,但对它整个的编曲过程还不是太熟悉.所以今天我就给大家带来了FL Studio20这款音乐编曲软件 ...
- guitar pro 系列教程(十八):Guitar Pro怎么设置吉他谱的局部速度?
关于Guitar Pro的使用功能我们在前面的文章也有讲了不少,对于新手的小伙伴,就小编个人而言,在吉他编曲,演绎方面遇到的困难不是一点两点,我们只有通过学习了解他的全部,才能在以后的吉他创作中得心印 ...
- 苹果电脑上folx下载器比迅雷还好用?
对于使用Mac电脑的小伙伴来说,除了迅雷以外,能够使用的下载工具非常少.小编也会经常被朋友问起,是否有好用的Mac下载工具推荐.小编都会毫不犹豫地推荐他们Folx,一款非常适用于Mac的下载工具.今天 ...
- 【PUPPETEER】初探之拖拽操作(五)
一.知识点 page.mouse elementHandle.boundingBox() ignoreDefaultArgs:['--enable-automation'] waitUntil 二 ...
- Codeforces Round #660 (Div. 2) A、B、C题解
A. Captain Flint and Crew Recruitment #构造 题目链接 题意 定义一类正整数,能够被\(p*q\)表示,其中\(p.q(1<p<q)\)均为素数,称之 ...
- Java基础教程——多态
直观地说,多态就是"一个对象,多种形态 ".比如观世音菩萨就有多种形态-- 每个人都有多种形态-- 具体地讲,多态是指"同一个对象.同一个方法(函数),表现出不同的行为& ...
- 用FL Studio基础版制作一首完整的电音
电音制作,自然少不了适合做电音的软件,市面上可以进行电音制作的软件不少,可是如果在这些软件中只能选择一款的话,想必多数人会把票投给FL Studio,毕竟高效率是永远不变的真理,今天就让我们来看看如何 ...