P13513 [KOI 2025 #1] 釜山观光
· 2 min read
题意简述
Hankook 和 Jeong-ul 两个人将在釜山停留 天,给定两个 字符串 表示各自日程。
若某人某天对应的日程字符为 ,则该人当天必须拥有至少一张有效票券。
可购买以下票券,求所需的最小费用:
- 单人 日票,价格 ;
- 单人 日票,价格 ;
- 单人 日票,价格 ;
- 双人 日票,价格 。
解题思路
考虑使用 DP 解决:设 表示 Hankook 前 天和 Jeong-ul 前 天都满足覆盖的最小费用。
边界情况 。
枚举 ,考虑三种情况的最小值:
- 覆盖 Hankook:;
- 覆盖 Jeong-ul:;
- 两人同时覆盖():。
时间复杂度为 。
参考代码
#include <bits/stdc++.h>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=2005;
int f[N][N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n,p1,p3,p5,pr;
string a,b;
cin>>n>>a>>b>>p1>>p3>>p5>>pr;
memset(f,0x3f,sizeof f);
for(int i=0;i<=n;i++)
{
for(int j=0;j<=n;j++)
{
if(i==0&&j==0){f[i][j]=0;continue;}
int t1=i==0?inf:min({f[i-1][j]+(a[i-1]-'0')*p1,f[max(0,i-3)][j]+p3,f[max(0,i-5)][j]+p5});
int t2=j==0?inf:min({f[i][j-1]+(b[j-1]-'0')*p1,f[i][max(0,j-3)]+p3,f[i][max(0,j-5)]+p5});
int t3=i!=j?inf:f[max(0,i-4)][max(0,j-4)]+pr;
f[i][j]=min({t1,t2,t3});
}
}
cout<<f[n][n]<<'\n';
return 0;
}