TOYOTA MOTOR CORPORATION Programming Contest 2023#1 (AtCoder Beginner Contest 298) A~G 题解

46 篇文章 7 订阅
43 篇文章 5 订阅

好久没写题解了,这就来水一篇。

A - Job Interview

题目大意

给定一个长为 N N N 的字符串 S S S,由 o-x 组成。

判断 S S S 是否符合下列条件:

  • S S S 中至少有一个 o
  • S S S 中没有 x

1 ≤ N ≤ 100 1\le N\le 100 1N100

分析

签到题。直接按题意模拟即可。

代码

#include <cstdio>
using namespace std;

int main()
{
	while(getchar() != '\n');
	char c;
	bool ok = false;
	while((c = getchar()) != '\n')
	{
		if(c == 'x')
		{
			puts("No");
			return 0;
		}
		if(c == 'o')
			ok = true;
	}
	puts(ok? "Yes": "No");
	return 0;
}

Python 水题大法 速通大法

input()
s = input()
print('Yes' if 'o' in s and 'x' not in s else 'No')

成功省掉 208 208 208个字符(


B - Coloring Matrix

题目大意

给定两个 N × N N\times N N×N 的矩阵 A A A B B B,都由 0 0 0 1 1 1 组成。

你可以将 A A A 顺时针旋转 0 ° , 90 ° , 180 ° 0\degree,90\degree,180\degree ,90°,180° 270 ° 270\degree 270°(任选其一)。

判断旋转后的 A A A 能否满足:

  • 对于每个 A i , j = 1 A_{i,j}=1 Ai,j=1 ( i , j ) (i,j) (i,j) B i , j = 1 B_{i,j}=1 Bi,j=1

1 ≤ N ≤ 100 1\le N\le 100 1N100

分析

原题中还贴心的给出了如何将一个矩阵旋转 90 ° 90\degree 90°,照题意模拟,旋转 4 4 4次并逐个判断即可。

代码

#include <cstdio>
#define maxn 105
using namespace std;

int a[maxn][maxn], b[maxn][maxn], c[maxn][maxn];

int main()
{
	int n;
	scanf("%d", &n);
	for(int i=0; i<n; i++)
		for(int j=0; j<n; j++)
			scanf("%d", a[i] + j);
	for(int i=0; i<n; i++)
		for(int j=0; j<n; j++)
			scanf("%d", b[i] + j);
	for(int x=0; x<4; x++)
	{
		for(int i=0; i<n; i++)
			for(int j=0; j<n; j++)
				c[i][j] = a[i][j];
		for(int i=0; i<n; i++)
			for(int j=0; j<n; j++)
				a[i][j] = c[n - 1 - j][i];
		for(int i=0; i<n; i++)
			for(int j=0; j<n; j++)
				if(a[i][j] && !b[i][j])
					goto bad; // goto 不是好习惯(改不掉了),千万不要学
		puts("Yes");
		return 0;
		bad:;
	}
	puts("No");
	return 0;
}

C - Cards Query Problem

题目大意

N N N 个盒子,编号 1 ∼ N 1\sim N 1N,初始均为空。依次处理 Q Q Q 次询问:

  • 1 i j:将数字 i i i 写在一张空卡牌上,放入盒子 j j j
  • 2 i:按升序输出盒子 i i i 中的所有卡牌(允许重复)。
  • 3 i:按升序输出包含卡牌 i i i 的所有盒子的编号。若一个盒子里有多张卡牌 i i i,则这个盒子的编号仅输出一次。

1 ≤ N , Q ≤ 2 × 1 0 5 1\le N,Q\le 2\times 10^5 1N,Q2×105

对于查询中所有卡牌上的数字 x x x,均有 1 ≤ x ≤ 2 × 1 0 5 1\le x\le 2\times 10^5 1x2×105
对于查询中所有的盒子编号 y y y,均有 1 ≤ y ≤ N 1\le y\le N 1yN

题目保证输出不超过 2 × 1 0 5 2\times 10^5 2×105 个整数。

分析

我们分别考虑两种输出操作的做法。

  • 2 i:很容易想到,既然要按升序输出,并且允许重复,我们可以使用 N N Nmultiset 来依次存储每个盒子中的卡牌,处理操作 1 1 1 时更新。
  • 3 i:首先不能从 N N N 个盒子中依次查找,这样明显会 TLE。正确的做法是,使用 2 × 1 0 5 2\times 10^5 2×105set(注意不能重复,所以不用 multiset)分别存储每张卡牌所在的箱子编号,处理操作 1 1 1 时更新。

此外,本题也可以使用 priority_queuemap,甚至直接输出时排序并去重,不过使用 set 的方式是最简单、代码量最少的。几种方法的总时间复杂度都是 O ( Q log ⁡ N ) \mathcal O(Q\log N) O(QlogN)

代码

#include <cstdio>
#include <set>
#define maxn 200005
using namespace std;

multiset<int> box[maxn];
set<int> has[maxn];

int main()
{
	int n, q;
	scanf("%d%d", &n, &q);
	while(q--)
	{
		int op, i;
		scanf("%d%d", &op, &i);
		if(op == 1)
		{
			int j;
			scanf("%d", &j);
			box[j].insert(i);
			has[i].insert(j);
		}
		else if(op == 2)
		{
			for(int x: box[i])
				printf("%d ", x);
			putchar('\n');
		}
		else if(op == 3)
		{
			for(int x: has[i])
				printf("%d ", x);
			putchar('\n');
		}
	}
	return 0;
}

D - Writing a Numeral

题目大意

我们有一个字符串 S S S。初始时, S = S= S= 1

处理如下 Q Q Q 次询问:

  • 1 x:将数字 x x x 追加至 S S S 的最后面。保证 x ∈ { 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 } x \in \{1,2,3,4,5,6,7,8,9\} x{1,2,3,4,5,6,7,8,9}
  • 2:删除 S S S 的第一个字符。保证此时 ∣ S ∣ > 1 |S|>1 S>1
  • 3:输出 S S S 在十进制中对应的数字,对 998244353 998244353 998244353 取模。

1 ≤ Q ≤ 6 × 1 0 5 1\le Q\le 6\times 10^5 1Q6×105

分析

首先,我们必须使用一个 queuedeque 来存储字符串 S S S。然后,为了在 O ( 1 ) \mathcal O(1) O(1) 的时间内处理第三种操作,我们必须维护 S   m o d   ( P = 998244353 ) S \bmod (P=998244353) Smod(P=998244353) 的值,记为 A A A。下面考虑前两种操作对 A A A 的影响:

  • 1 x:只需在十进制中腾出一位 0 0 0 再加上 x x x 即可,可表示为 A ← ( 10 A + x )   m o d   P A \leftarrow (10A+x)\bmod P A(10A+x)modP
  • 2:先从队列中取出 S S S 的第一位,记为 x x x。我们需要从 A A A 中减掉最高位乘上其在十进制中的权值,即 A ← ( A − 1 0 ∣ S ∣ x )   m o d   P A \leftarrow (A-10^{|S|}x)\bmod P A(A10Sx)modP(此时 ∣ S ∣ |S| S 表示队列取出前一位后的长度,等同于取出前的 ∣ S ∣ − 1 |S|-1 S1

对于 1 0 n 10^n 10n 的计算,我们可以用一个变量实时维护 1 0 ∣ S ∣   m o d   P 10^{|S|}\bmod P 10SmodP 的值,也可以预处理出所有 1 0 n   m o d   P 10^n \bmod P 10nmodP,或者直接使用快速幂。

总时间复杂度为 O ( Q log ⁡ Q ) \mathcal O(Q\log Q) O(QlogQ)(快速幂)或 O ( Q ) \mathcal O(Q) O(Q)(预处理)。

代码

实现 1 1 1:使用 AtCoder Library + 快速幂,队列使用 deque

#include <cstdio>
#include <deque>
#include <atcoder/modint>
using namespace std;

using modint = atcoder::modint998244353;

int main()
{
	deque<int> s;
	s.push_back(1);
	int q;
	scanf("%d", &q);
	modint ans = 1;
	while(q--)
	{
		int op;
		scanf("%d", &op);
		if(op == 1)
		{
			int x;
			scanf("%d", &x);
			s.push_back(x);
			ans = ans * 10 + x;
		}
		else if(op == 2)
		{
			int x = s.front(); s.pop_front();
			ans -= x * modint(10).pow((int)s.size());
		}
		else printf("%d\n", ans.val());
	}
	return 0;
}

实现 2 2 2:用变量维护 1 0 ∣ S ∣   m o d   P 10^{|S|} \bmod P 10SmodP 的值,队列使用 queue

#include <cstdio>
#include <queue>
#define MOD 998244353
using namespace std;

int main()
{
	int Q;
	scanf("%d", &Q);
	queue<int> q;
	q.push(1);
	int ans = 1, p = 1;
	while(Q--)
	{
		int op;
		scanf("%d", &op);
		if(op == 1)
		{
			int x;
			scanf("%d", &x);
			q.push(x);
			ans = (ans * 10LL + x) % MOD;
			p = p * 10LL % MOD;
		}
		else if(op == 2)
		{
			ans -= (long long) q.front() * p % MOD; q.pop();
			p = p * 299473306LL % MOD; // 299473306 是 10 对于 MOD 的逆元,这句话相当于把 p 除以 10 
			if(ans < 0) ans += MOD;
		}
		else printf("%d\n", ans);
	}
	return 0;
}

E - Unfair Sugoroku

题目大意

Takahashi 和 Aoki 将玩一个游戏。游戏规则如下:

  • 游戏棋盘有 N N N 个点(编号 1 ∼ N 1\sim N 1N),两玩家轮流投骰子并前进。
  • Takahashi 初始在点 A A A,Aoki 初始在点 B B B
  • Takahashi 的骰子等概率出现 1 , 2 , … , P 1,2,\dots,P 1,2,,P,Aoki 的骰子等概率出现 1 , 2 , … , Q 1,2,\dots,Q 1,2,,Q
  • 当一个玩家当前在点 x x x 且骰子出现 i i i 时,他移动到点 min ⁡ ( x + i , N ) \min(x+i,N) min(x+i,N)
  • 先到达点 N N N 的玩家胜利。

假定 Takahashi 先行,求他赢的概率,对 998244353 998244353 998244353 取模。

2 ≤ N ≤ 100 2\le N\le 100 2N100
1 ≤ A , B ≤ N 1\le A,B\le N 1A,BN
1 ≤ P , Q ≤ 10 1\le P,Q\le 10 1P,Q10

分析

自己的赛时解法太复杂了,这里介绍官方题解的做法。

考虑概率 DP(下面用 Ta 表示 Takahashi,Ao 表示 Aoki):

  • f i , j f_{i,j} fi,j 表示 Ta 在点 i i i,Ao 在点 j j j,下一轮 Ta 移动时 Ta 获胜的概率。
  • g i , j g_{i,j} gi,j 表示 Ta 在点 i i i,Ao 在点 j j j,下一轮 Ao 移动时 Ta 获胜的概率。

首先考虑初始状态。根据游戏规则,对于任意 1 ≤ i < n 1\le i<n 1i<n f n , i = g n , i = 1 , f i , n = g i , n = 0 f_{n,i}=g_{n,i}=1,f_{i,n}=g_{i,n}=0 fn,i=gn,i=1,fi,n=gi,n=0

转移也很显然:

  • 对于 Ta 当前走的每种可能的步数 k = 1 , 2 , … , P k=1,2,\dots,P k=1,2,,P,有 f i , j : = f i , j + 1 P g min ⁡ ( i + k , N ) , j f_{i,j}:=f_{i,j}+\frac1Pg_{\min(i+k,N),j} fi,j:=fi,j+P1gmin(i+k,N),j
  • 对于 Ao 当前走的每种可能的步数 k = 1 , 2 , … , Q k=1,2,\dots,Q k=1,2,,Q,有 g i , j : = g i , j + 1 Q f i , min ⁡ ( j + k , N ) g_{i,j}:=g_{i,j}+\frac1Qf_{i,\min(j+k,N)} gi,j:=gi,j+Q1fi,min(j+k,N)

整理上面的式子,得到:
f i , j = { 0 ( j = N ) 1 ( i = N ) 1 P ∑ k = 1 P g min ⁡ ( i + k , N ) , j ( i , j ≠ N )   g i , j = { 0 ( j = N ) 1 ( i = N ) 1 Q ∑ k = 1 Q f i , min ⁡ ( j + k , N ) ( i , j ≠ N ) f_{i,j}=\begin{cases} 0 & (j=N)\\ 1 & (i=N)\\ \frac1P\sum\limits_{k=1}^Pg_{\min(i+k,N),j} & (i,j\ne N) \end{cases}\\ ~\\ g_{i,j}=\begin{cases} 0 & (j=N)\\ 1 & (i=N)\\ \frac1Q\sum\limits_{k=1}^Qf_{i,\min(j+k,N)} & (i,j\ne N) \end{cases}\\ fi,j= 01P1k=1Pgmin(i+k,N),j(j=N)(i=N)(i,j=N) gi,j= 01Q1k=1Qfi,min(j+k,N)(j=N)(i=N)(i,j=N)
这里注意,由于 i = j = N i=j=N i=j=N 的情况无意义(不可能达到),所以无需特殊考虑。

最终输出结果即为 f p , q f_{p,q} fp,q。总时间复杂度为 O ( N 2 ( P + Q ) ) \mathcal O(N^2(P+Q)) O(N2(P+Q))。使用前缀和可以优化到 O ( N 2 ) \mathcal O(N^2) O(N2),有兴趣的可以自己尝试,这里不详细解释了。

代码

#include <cstdio>
#include <algorithm>
#define MOD 998244353
#define maxn 105
using namespace std;

using LL = long long;
inline LL inv(LL x) // x ^ (MOD - 2) % MOD
{
	int y = MOD - 2;
	LL res = 1LL;
	while(y)
	{
		if(y & 1) (res *= x) %= MOD;
		(x *= x) %= MOD, y >>= 1;
	}
	return res;
}

inline void add(int& x, int y)
{
	if((x += y) >= MOD)
		x -= MOD;
}

int f[maxn][maxn], g[maxn][maxn];

int main()
{
	int n, a, b, p, q;
	scanf("%d%d%d%d%d", &n, &a, &b, &p, &q);
	for(int i=0; i<n; i++)
		f[n][i] = g[n][i] = 1, f[i][n] = g[i][n] = 0;
	LL prob_p = inv(p), prob_q = inv(q);
	for(int i=n-1; i>=a; i--)
		for(int j=n-1; j>=b; j--)
		{
			for(int k=1; k<=p; k++)
				add(f[i][j], g[min(i + k, n)][j]);
			f[i][j] = f[i][j] * prob_p % MOD;
			for(int k=1; k<=q; k++)
				add(g[i][j], f[i][min(j + k, n)]);
			g[i][j] = g[i][j] * prob_q % MOD;
		}
	printf("%d\n", f[a][b]);
	return 0;
}

F - Rook Score

题目大意

有一个 1 0 9 × 1 0 9 10^9\times 10^9 109×109 的网格。令 ( i , j ) (i,j) (i,j) 表示第 i i i j j j 列的格子( 1 ≤ i , j ≤ 1 0 9 1\le i,j\le 10^9 1i,j109)。

对于 i = 1 , 2 , … , N i=1,2,\dots,N i=1,2,,N,整数 x i x_i xi 被写在 ( r i , c i ) (r_i,c_i) (ri,ci) 上。在剩余的 1 0 18 − N 10^{18}-N 1018N 个格子里只有数字 0 0 0

你可以选择一个格子 ( R , C ) (R,C) (R,C) 并计算与其同行或同列的 2 × 1 0 9 − 1 2\times 10^9-1 2×1091 个整数之和 S S S

求最大可能的 S S S

1 ≤ N ≤ 2 × 1 0 5 1\le N\le 2\times 10^5 1N2×105
1 ≤ r i , c i , x i ≤ 1 0 9 1\le r_i,c_i,x_i\le 10^9 1ri,ci,xi109
( r i , c i ) ≠ ( r j , c j )        ( i ≠ j ) (r_i,c_i)\ne (r_j,c_j)~~~~~~(i\ne j) (ri,ci)=(rj,cj)      (i=j)

分析

我们令 f ( R , C ) f(R,C) f(R,C) 表示对于 ( R , C ) (R,C) (R,C) S S S,令 r s R \mathrm{rs}_R rsR 表示第 R R R 行的整数之和, c s C \mathrm{cs}_C csC表示第 C C C 列的整数之和, A R , C A_{R,C} AR,C 表示 ( R , C ) (R,C) (R,C) 上的整数。

容易发现, f ( R , C ) = r s R + c s C − A R , C f(R,C)=\mathrm{rs}_R+\mathrm{cs}_C-A_{R,C} f(R,C)=rsR+csCAR,C

然后证明当 f ( R , C ) f(R,C) f(R,C) 最大时, r s R , c s C ≠ 0 \mathrm{rs}_R,\mathrm{cs}_C\ne0 rsR,csC=0

  • r s R = c s C = 0 \mathrm{rs}_R=\mathrm{cs}_C=0 rsR=csC=0,则 f ( r 0 , c 0 ) = x 0 > 0 = f ( R , C ) f(r_0,c_0)=x_0>0=f(R,C) f(r0,c0)=x0>0=f(R,C),所以 ( R , C ) (R,C) (R,C) 不是最优解;
  • r s R ≠ 0 , c s C = 0 \mathrm{rs}_R\ne0,\mathrm{cs}_C=0 rsR=0,csC=0,则 f ( R , c 0 ) = r s R + c s c 0 − A R , c 0 ≥ f ( R , C ) = r s R f(R,c_0)=\mathrm{rs}_R+\mathrm{cs}_{c_0}-A_{R,c_0}\ge f(R,C)=\mathrm{rs}_R f(R,c0)=rsR+csc0AR,c0f(R,C)=rsR,所以 ( R , C ) (R,C) (R,C) 不是最优解(或有多个最优解,但其中至少有一个解 ( x , y ) (x,y) (x,y) 使得 r s x , c s y ≠ 0 \mathrm{rs}_x,\mathrm{cs}_y\ne0 rsx,csy=0
  • r s R = 0 , c s C ≠ 0 \mathrm{rs}_R=0,\mathrm{cs}_C\ne0 rsR=0,csC=0 同理。

所以,我们可以依次考虑每一行 R R R r s R ≠ 0 \mathrm{rs}_R\ne 0 rsR=0),相当于固定了 r s R \mathrm{rs}_R rsR。这时,我们只需找到一列 C C C c s C ≠ 0 \mathrm{cs}_C\ne 0 csC=0),使得 c s C − A R , C \mathrm{cs}_C-A_{R,C} csCAR,C 最大,就可以解决此问题。

但如果依次考虑所有包含点的列,则最坏情况下时间复杂度为 O ( N 2 ) \mathcal O(N^2) O(N2),无法通过此题。这时,我们可以使用一个 multisetmap 来维护当前每列对答案的贡献( c s C − A R , C \mathrm{cs}_C-A_{R,C} csCAR,C)。对于每一行 R R R,仅需更新这一行上有非 0 0 0 数字的点 ( R , C ) (R,C) (R,C) 的贡献(减去 A R , C A_{R,C} AR,C)即可。

这样,由于每个点会被更新正好一次,所以总时间复杂度为 O ( N log ⁡ N ) \mathcal O(N\log N) O(NlogN)

代码

注意更新完成,求得当前答案后需要复原 mapmultiset

#include <cstdio>
#include <vector>
#include <set>
#include <unordered_map>
using namespace std;

using LL = long long;
using pii = pair<int, int>;

unordered_map<int, vector<pii>> rows;
unordered_map<int, LL> col_sum;

template <typename T>
class MaxSet {
private:
	multiset<T> s;
public:
	inline void insert(const T& x) { s.insert(x); }
	inline void update(const T& old, const T& New) {
		s.erase(s.find(old));
		s.insert(New);
	}
	inline T max() { return *s.rbegin(); }
};

int main()
{
	int n;
	scanf("%d", &n);
	while(n--)
	{
		int x, y, v;
		scanf("%d%d%d", &x, &y, &v);
		rows[x].emplace_back(y, v);
		col_sum[y] += v;
	}
	MaxSet<LL> s;
	for(auto [_, sum]: col_sum)
		s.insert(sum);
	LL ans = 0LL;
	for(auto& [x, v]: rows)
	{
		for(auto [y, val]: v)
			s.update(col_sum[y], col_sum[y] - val);
		LL cur = s.max();
		for(auto [y, val]: v)
			s.update(col_sum[y] - val, col_sum[y]), cur += val;
		if(cur > ans) ans = cur;
	}
	printf("%lld\n", ans);
	return 0;
}

G - Strawberry War

题目大意

注意本题时间限制为 6 s 6\mathrm s 6s

我们有一块长方形的蛋糕。它可被看作一个 H × W H\times W H×W 的网格,第 i i i j j j 列上有 s i , j s_{i,j} si,j 个草莓。

我们对蛋糕进行 T T T 次切分,切成 T + 1 T+1 T+1 块。每次切蛋糕可以选择当前的一块,并将其从中间横切或竖切成两块:
切分方式

你想把蛋糕切的尽可能均匀。意思是,令 M M M 表示切分完成后每一块上的草莓数量的最大值, m m m 表示最小值,求出 M − m M-m Mm 的最小值。

1 ≤ H , W ≤ 6 1\le H,W\le 6 1H,W6
1 ≤ T ≤ H W − 1 1\le T\le HW-1 1THW1
0 ≤ s i , j ≤ 1 0 16 0\le s_{i,j}\le 10^{16} 0si,j1016

分析

本题解参考官方题解

操作完成后得到的蛋糕一定是蛋糕的子矩形,所以最多只有 ( H + 1 2 ) × ( W + 1 2 ) = H ( H + 1 ) W ( W + 1 ) 4 ≤ 441 \binom {H+1}2\times\binom {W+1}2=\frac{H(H+1)W(W+1)}4\le 441 (2H+1)×(2W+1)=4H(H+1)W(W+1)441 种数字在剩下的块中。令这些可能的数分别为 a 1 , a 2 , … , a X a_1,a_2,\dots,a_X a1,a2,,aX。可知 X ≤ H ( H + 1 ) W ( W + 1 ) 4 ≤ 441 X\le \frac{H(H+1)W(W+1)}4\le 441 X4H(H+1)W(W+1)441

根据上面的 a a a,我们只需先确定 m ∈ { a 1 , a 2 , … , a X } m\in \{a_1,a_2,\dots,a_X\} m{a1,a2,,aX},再找到与其对应的最小 M M M,算出 M − m M-m Mm 的最小值即可。

定义 f i , j , k , l , m f_{i,j,k,l,m} fi,j,k,l,m 表示将 x ∈ [ i , j ) , y ∈ [ k , l ) x\in[i,j),y\in[k,l) x[i,j),y[k,l) 的子矩形切成 m m m 片时最小可能的每片上草莓数的最大值。

详见代码。

代码

#include <bits/stdc++.h>
using namespace std;
const long long INF = 1000000000000000000;
int main(){
  int H, W, T;
  cin >> H >> W >> T;
  vector<vector<long long>> s(H, vector<long long>(W));
  for (int i = 0; i < H; i++){
    for (int j = 0; j < W; j++){
      cin >> s[i][j];
    }
  }
  vector<vector<vector<vector<long long>>>> sum(H, vector<vector<vector<long long>>>(H + 1, vector<vector<long long>>(W, vector<long long>(W + 1, 0))));
  vector<long long> x;
  for (int i = 0; i < H; i++){
    for (int j = i + 1; j <= H; j++){
      for (int k = 0; k < W; k++){
        for (int l = k + 1; l <= W; l++){
          for (int m = i; m < j; m++){
            for (int n = k; n < l; n++){
              sum[i][j][k][l] += s[m][n];
            }
          }
          x.push_back(sum[i][j][k][l]);
        }
      }
    }
  }
  int cnt = x.size();
  long long ans = INF;
  for (int i = 0; i < cnt; i++){
    vector<vector<vector<vector<vector<long long>>>>> dp(T + 1, vector<vector<vector<vector<long long>>>>(H, vector<vector<vector<long long>>>(H + 1, vector<vector<long long>>(W, vector<long long>(W + 1, INF)))));
    for (int j = H - 1; j >= 0; j--){
      for (int k = j + 1; k <= H; k++){
        for (int l = W - 1; l >= 0; l--){
          for (int m = l + 1; m <= W; m++){
            if (sum[j][k][l][m] >= x[i]){
              dp[0][j][k][l][m] = sum[j][k][l][m];
            }
            for (int n = j + 1; n < k; n++){
              for (int o = 0; o < (n - j) * (m - l); o++){
                for (int p = 0; p < (k - n) * (m - l) && o + p < T; p++){
                  dp[o + p + 1][j][k][l][m] = min(dp[o + p + 1][j][k][l][m], max(dp[o][j][n][l][m], dp[p][n][k][l][m]));
                }
              }
            }
            for (int n = l + 1; n < m; n++){
              for (int o = 0; o < (k - j) * (n - l); o++){
                for (int p = 0; p < (k - j) * (m - n) && o + p < T; p++){
                  dp[o + p + 1][j][k][l][m] = min(dp[o + p + 1][j][k][l][m], max(dp[o][j][k][l][n], dp[p][j][k][n][m]));
                }
              }
            }
          }
        }
      }
    }
    ans = min(ans, dp[T][0][H][0][W] - x[i]);
  }
  cout << ans << endl;
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值