洛谷P4170 [CQOI2007] 涂色题解

题目传送门

思路

我们不难想到,本题是一道区间dp.

为区间[l,r]的最小涂色次数

很显然,的答案一定为1

当区间[i,j]的首尾不同时,即无法通过覆盖等方式减少涂色次数时,

当区间[i,j]的首尾相同时,如样例2的区间[1,5],首尾颜色都是R,我们就可以先全涂成R,再对区间[2,5]进行涂色,我们可以发现,最后的R(或第一个R)并没有消耗涂色次数,所以,由于一定不大于,所以我们并不需要进入循环取枚举分割点来再求一遍,这样可以减少一点时间复杂度

本题时间复杂度最大为

代码

cpp 复制代码
#include<bits/stdc++.h>
#define endl '\n';
using namespace std;
string s;
int n;
int f[60][60];
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>s;
	int n=s.length();
	memset(f,0x3f,sizeof(f));
	for(int i=1;i<=n;i++)f[i][i]=1;
	for(int i=1;i<=n;i++){
		for(int j=1;j+i-1<=n;j++){
			int r=j+i-1;
			if(s[r-1]==s[j-1])f[j][r]=min(f[j][r],min(f[j+1][r],f[j][r-1]));
			else{
				for(int k=j;k<r;k++){
					f[j][r]=min(f[j][r],f[j][k]+f[k+1][r]);
				}
			}
		}
	}cout<<f[1][n];
	return 0;
}
相关推荐
tanyongxi6613 分钟前
C++ 特殊类设计与单例模式解析
java·开发语言·数据结构·c++·算法·单例模式
qq_5139704414 分钟前
力扣 hot100 Day76
算法·leetcode·职场和发展
Moshow郑锴1 小时前
机器学习相关算法:回溯算法 贪心算法 回归算法(线性回归) 算法超参数 多项式时间 朴素贝叶斯分类算法
算法·机器学习·回归
liulilittle1 小时前
BFS寻路算法解析与实现
开发语言·c++·算法·宽度优先·寻路算法·寻路
剪一朵云爱着1 小时前
PAT 1065 A+B and C (64bit)
算法·pat考试
喜欢吃燃面2 小时前
C++算法竞赛:位运算
开发语言·c++·学习·算法
项目申报小狂人2 小时前
算法应用上新!自适应更新策略差分进化算法求解球形多飞行器路径规划问题,附完整MATLAB代码
开发语言·算法·matlab
PAK向日葵8 小时前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者10 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶