首页 > 其他分享 >题解 [ABC227F] Treasure Hunting

题解 [ABC227F] Treasure Hunting

时间:2022-11-11 22:00:14浏览次数:49  
标签:Hunting Contest 题解 rep Treasure ABC227F ll dp

简单 DP,当时赛时没做出来,怎么回事呢。

在 DP 过程中并不好维护前 \(k\) 大都是什么,没有办法把它放到状态里,因此我们枚举第 \(k\) 大数的下标 \(a_{x,y}\)。

然后就好办了,设 \(dp_{i,j,t}\) 表示从 \((1,1)\) 走到 \((i,j)\),且路径上有 \(t\) 个数在前 \(k\) 大中时的答案。

有两种转移:

  • 当 \(a_{i,j}\ge a_{x,y}\) 时,\(a_{i,j}\) 可以在前 \(k\) 大中,转移为 \(dp_{i,j,t}=\min\{dp_{i-1,j,t-1},dp_{i,j-1,t-1}\}+a_{i,j}\)。
  • 当 \(a_{i,j}\le a_{x,y}\) 时,\(a_{i,j}\) 可以不在前 \(k\) 大中,转移为 \(dp_{i,j,t}=\min\{dp_{i-1,j,t},dp_{i,j-1,t}\}\)。

取每一个 \(a_{x,y}\) 时的 \(dp_{n,m,k}\) 最小值即可。

// Problem: F - Treasure Hunting
// Contest: AtCoder - KEYENCE Programming Contest 2021 (AtCoder Beginner Contest 227)
// URL: https://atcoder.jp/contests/abc227/tasks/abc227_f
// Memory Limit: 1024 MB
// Time Limit: 3000 ms
// 
// Powered by CP Editor (https://cpeditor.org)

//By: OIer rui_er
#include <bits/stdc++.h>
#define rep(x,y,z) for(ll x=(y);x<=(z);x++)
#define per(x,y,z) for(ll x=(y);x>=(z);x--)
#define debug(format...) fprintf(stderr, format)
#define fileIO(s) do{freopen(s".in","r",stdin);freopen(s".out","w",stdout);}while(false)
using namespace std;
typedef long long ll;
const ll N = 35, inf = 0x3f3f3f3f3f3f3f3fll;

ll n, m, k, a[N][N], dp[N][N][2*N], ans = inf;
template<typename T> void chkmin(T& x, T y) {if(x > y) x = y;}
template<typename T> void chkmax(T& x, T y) {if(x < y) x = y;}

int main() {
	scanf("%lld%lld%lld", &n, &m, &k);
	rep(i, 1, n) rep(j, 1, m) scanf("%lld", &a[i][j]);
	rep(x, 1, n) {
		rep(y, 1, m) {
			memset(dp, 0x3f, sizeof(dp));
			dp[0][1][0] = 0;
			rep(i, 1, n) {
				rep(j, 1, m) {
					if(a[i][j] >= a[x][y]) {
						rep(t, 1, k) {
							chkmin(dp[i][j][t], dp[i-1][j][t-1] + a[i][j]);
							chkmin(dp[i][j][t], dp[i][j-1][t-1] + a[i][j]);
						}
					}
					if(a[i][j] <= a[x][y]) {
						rep(t, 0, k) {
							chkmin(dp[i][j][t], dp[i-1][j][t]);
							chkmin(dp[i][j][t], dp[i][j-1][t]);
						}
					}
				}
			}
			chkmin(ans, dp[n][m][k]);
		}
	}
	printf("%lld\n", ans);
	return 0;
}

标签:Hunting,Contest,题解,rep,Treasure,ABC227F,ll,dp
From: https://www.cnblogs.com/ruierqwq/p/abc227f.html

相关文章

  • CF1750E 题解
    没看懂官方社论,只好自力更生了。我们很容易知道,对于一段区间,其代价就是多余的括号数(左右括号中多出来的括号数)加上不属于多余括号,但没有匹配的左或右括号数。即左括号总量......
  • CF1252K Addition Robot 题解
    题目链接思路对于\(A=A+B\),\(B=A+B\)这种的递推式可以考虑矩阵加速递推,可得:\[\left(\begin{matrix}A+B&B\end{matrix}\right)=\left(\begin{ma......
  • P5443 [APIO2019] 桥梁 题解
    容易得出一种暴力算法:将询问按\(w\)排序,将没有修改的边按\(d\)排序。对于每个询问\((t_i,s_i,w_i)\),做两部分操作(这里\(t\)是时间的意思):将没有修改的边中满足\(d......
  • P1587 [NOI2016] 循环之美 题解
    P1587[NOI2016]循环之美这道题我推到后面推不下去了,最后还是看了题解。还是切不了这种题唉。前置知识:杜教筛开始时看不出什么,我们先用经验和手玩来找一下规律。我们......
  • P6628 [省选联考 2020 B 卷] 丁香之路 题解
    图论、贪心好题。枚举每一个朋友,设一个朋友从\(s\)出发,到\(t\)结束。那么如果用边来表示其行动轨迹,必然是\(s,t\)有奇数度,其它点均为偶数度。如果在\(s,t\)之间连......
  • CF464D World of Darkraft - 2 题解
    期望好题,可以帮助我们更加深入地了解期望。由于\(k\)种装备相同,所以只要计算卖掉一种装备得到的金币期望乘以\(k\)就行了。为了避免讨论当前状态的概率,期望DP通常......
  • CF1316E Team Building 题解
    可能更好的阅读体验题目传送门题目大意传送门你需要组建一支排球队。为了组织一支排球队,你需要为队伍里的\(p\)个不同的位置,从\(n\)个人中选出\(p\)个人,且每个位......
  • CF1735E题解
    钦定\(p_1=0,p_2>0\),不难证明如果有解则一定存在\(p_2>p_1\)的解。考虑枚举和\(d_{1,1}\)是相同楼房,则\(p_2\)对于每一种情况有两种可能的位置:\(d_{1,1}+d_{2,i}\)......
  • P3188 [HNOI2007]梦幻岛宝珠 题解
    一道不错的dp题,下令原背包容量为\(m\)。注意到\(w_i=a\times2^b\)中\(a,b\)都比较小,尝试按照\(a\)或者\(b\)分组然后合并,但是显然如果我们按照\(a\)分组就......
  • 汉诺塔问题及其变种问题解法(cpp版本)
    普通汉诺塔问题1.问题描述有三个柱子A、B、C,A柱子上有n个圆盘,圆盘的大小不等,大圆盘的在下,小圆盘的在上。将A柱子上的圆盘全部移动到C柱子上。每次只能移动一个圆盘,而且......