首页 > 其他分享 >AtCoder Beginner Contest 219 H Candles

AtCoder Beginner Contest 219 H Candles

时间:2023-06-14 21:58:58浏览次数:59  
标签:AtCoder typedef 得分 Candles ll Contest long 219 蜡烛

洛谷传送门

AtCoder 传送门

套路化了。

比较显然的关路灯型区间 dp。考虑你 \(t\) 时刻熄灭一个初始长度为 \(a\) 的蜡烛,得分是 \(\max(a - t, 0)\),所以尝试把时间塞进状态。设 \(f_{i, j, k, 0/1}\) 表示,熄灭完区间 \([i, j]\) 的蜡烛,当前时间是 \(t\),在左端点还是右端点的最大得分。转移考虑走的路径即可。

发现时间可能很大,并且已经没有优化的余地了。考虑换种思路,假设我一开始得了 \(\sum\limits_{i = 1}^n a_i\) 分,然后我每走一个单位距离,得分减少 \(k\),\(k\) 是还剩下的蜡烛数量。但是你发现一个很麻烦的事情是,熄灭蜡烛时得分要与 \(0\) 取 \(\max\),但是你到这个蜡烛的时候它的得分已经是负数了。

考虑直接钦定每个蜡烛的长度是否计入最后得分,称这样的蜡烛是有效的,这样如果遇到负数得分的蜡烛,最优解一定是不把它当成有效。状态添加一维 \(k\) 表示熄灭区间 \([i, j]\) 的蜡烛后还剩下 \(k\) 个有效蜡烛。转移就根据关路灯的基础上再讨论当前熄灭的这个蜡烛是否有效即可。

没了?

代码很好写。时间复杂度 \(O(n^3)\)。

code
// Problem: H - Candles
// Contest: AtCoder - Sciseed Programming Contest 2021(AtCoder Beginner Contest 219)
// URL: https://atcoder.jp/contests/abc219/tasks/abc219_h
// Memory Limit: 1024 MB
// Time Limit: 2000 ms
// 
// Powered by CP Editor (https://cpeditor.org)

#include <bits/stdc++.h>
#define pb emplace_back
#define fst first
#define scd second
#define mems(a, x) memset((a), (x), sizeof(a))

using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef double db;
typedef long double ldb;
typedef pair<ll, ll> pii;

const int maxn = 310;

ll n, m, f[maxn][maxn][maxn][2];
struct node {
	ll x, y;
	node(ll a = 0, ll b = 0) : x(a), y(b) {}
} a[maxn];

void solve() {
	scanf("%lld", &n);
	for (int i = 1; i <= n; ++i) {
		scanf("%lld%lld", &a[i].x, &a[i].y);
	}
	a[++n] = node(0, 0);
	sort(a + 1, a + n + 1, [&](node a, node b) {
		return a.x < b.x;
	});
	int p = -1;
	for (int i = 1; i <= n; ++i) {
		if (!a[i].y) {
			p = i;
			break;
		}
	}
	mems(f, -0x3f);
	for (int i = 0; i <= n; ++i) {
		f[p][p][i][0] = f[p][p][i][1] = 0;
	}
	for (int p = 2; p <= n; ++p) {
		for (int i = 1, j = p; j <= n; ++i, ++j) {
			for (int k = 0; k <= n; ++k) {
				f[i][j][k][0] = max({f[i + 1][j][k][0] - (a[i + 1].x - a[i].x) * k, f[i + 1][j][k + 1][0] - (a[i + 1].x - a[i].x) * (k + 1) + a[i].y, f[i + 1][j][k][1] - (a[j].x - a[i].x) * k, f[i + 1][j][k + 1][1] - (a[j].x - a[i].x) * (k + 1) + a[i].y});
				f[i][j][k][1] = max({f[i][j - 1][k][0] - (a[j].x - a[i].x) * k, f[i][j - 1][k + 1][0] - (a[j].x - a[i].x) * (k + 1) + a[j].y, f[i][j - 1][k][1] - (a[j].x - a[j - 1].x) * k, f[i][j - 1][k + 1][1] - (a[j].x - a[j - 1].x) * (k + 1) + a[j].y});
			}
		}
	}
	ll ans = 0;
	for (int i = 1; i <= n; ++i) {
		for (int j = i; j <= n; ++j) {
			for (int k = 0; k <= n; ++k) {
				ans = max({ans, f[i][j][k][0], f[i][j][k][1]});
			}
		}
	}
	printf("%lld\n", ans);
}

int main() {
	int T = 1;
	// scanf("%d", &T);
	while (T--) {
		solve();
	}
	return 0;
}

标签:AtCoder,typedef,得分,Candles,ll,Contest,long,219,蜡烛
From: https://www.cnblogs.com/zltzlt-blog/p/17481457.html

相关文章

  • AtCoder Beginner Contest 223 H Xor Query
    洛谷传送门AtCoder传送门考虑一个无脑做法:线段树维护区间线性基。时间复杂度是\(O(m\logn\log^2V)\),过于优秀以至于无法接受。事实上我们并不需要维护区间线性基,因为不带修。考虑“可持久化线性基”,开\(n\)个线性基,第\(i\)个维护前缀\([1,i]\)的数。并且插入线性......
  • AtCoder Beginner Contest 215 H Cabbage Master
    洛谷传送门AtCoder传送门考虑第一问。发现这个东西长得很像二分图匹配,考虑建图,第\(i\)个盒子建\(b_i\)个左部点,第\(i\)个球建\(a_i\)个右部点,每个盒子的每个点往可以放的球的每个点连边。显然要求能被满足等价于,这个二分图存在一个左部点的完全匹配。因为一个盒子的......
  • CSGO服务器租用首选杭州BGP高防103.219.30.x
    Hello,everyone今天我不打算讲游戏攻略了,我了解到很多想要自己搭建服务器的小伙伴在服务器这里遇到颈瓶了,所以我来给大家分享一下搭建CSGO社区服所需的服务器配置,希望可以帮助到你们首先选择合适的服务器配置,第一个需要考虑的就是游戏玩家地区分布情况,我很多玩CSGO的朋友都来自五湖......
  • AtCoder Regular Contest 141 C Bracket and Permutation
    洛谷传送门AtCoder传送门考虑给出\(S\),如何求\(P,Q\)。先考虑\(P\),那我们肯定想让\(P\)的每一项都尽量往前靠。设\([1,k]\)为合法括号串,\(S_{k+1}=\texttt{)}\),那\(P\)的前\(k\)项依次为\(1\simk\),第\(k+1\)项不能为\(k+1\)了,那找到\(k+1\)之......
  • AtCoder Beginner Contest 273(E)
    AtCoderBeginnerContest273(E)E(链式结构,思维)E题目大意就是原本有一个空的序列,我们后面会进行\(q\)次操作,每次操作我们都需要输出此时的序列的最后数字下面有几种操作\(ADD\)\(x\),代表在这在这个序列的最后面添加一个\(x\)\(DELETE\),代表如果此时的序列存在数字的话,......
  • 操作系统 4804af79a21946779f8bd2b1e90e1579
    操作系统2^16=655362^10=10242^8=256选择杂项分时系统中,为使多个用户能够同时与系统交互,最关键的问题是:能在一短的时间内,使所有用户程序都能运行当用户数目为100时,为保证响应不超过2秒,此时时间片最大应为:2s=2000ms2000/100=20ms进程三种状态级变化(进程动态,程序静态)......
  • AtCoder Beginner Contest 265 F Manhattan Cafe
    洛谷传送门AtCoder传送门考虑dp,\(f_{i,j,k}\)表示考虑到第\(i\)维,\(\sum\limits_{x=1}^i|p_x-r_x|=j,\sum\limits_{x=1}^i|q_x-r_x|=k\)的方案数。转移是容易的,枚举\(r_i\)即可,\(f_{i,j,k}=\sum\limits_rf_{i-1,j-|p_i-r|,k-|q_i-r|}......
  • Atcoder Beginner Contest 301
    A-OverallWinner题目大意A和T两人玩游戏,给定一串只由A和T组成的字符串,如果第i个字符是A,则A赢得第i轮的胜利,反之则T赢;当遍历完整个字符串后,谁赢的轮数多谁就是最终赢家,如果一样则谁最先达到该轮数谁赢,输出赢家的名字解题思路签到题不多嗦了神秘代码......
  • AtCoder Beginner Contest 278 ABCDE
    AtCoderBeginnerContest278A-ShiftProblemStatement题意:给你一个长度为n的序列,让你移走前面k个后面补k个0。Solution思路:按照题意模拟即可。#include<bits/stdc++.h>usingnamespacestd;inta[1100];intmain(){ intn,k; cin>>n>>k; k=min(k,n); for(int......
  • UNIQUE VISION Programming Contest 2023 New Year (AtCoder Beginner Contest 287) A
    UNIQUEVISIONProgrammingContest2023NewYear(AtCoderBeginnerContest287)A-MajorityProblemStatement题意:给你n个字符串,字符串是For表示agree,字符串Against表示disagree,让你判断最终是否通过。Solution思路:统计For和Against的数量,比较一下即可。#include......