洛谷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;
}
相关推荐
励志要当大牛的小白菜25 分钟前
ART配对软件使用
开发语言·c++·qt·算法
qq_5139704429 分钟前
力扣 hot100 Day56
算法·leetcode
PAK向日葵1 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱喝矿泉水的猛男3 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao4 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7724 小时前
Traffic Lights set的使用
算法
go54631584656 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae6 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法
大锦终6 小时前
【算法】前缀和经典例题
算法·leetcode
想变成树袋熊6 小时前
【自用】NLP算法面经(6)
人工智能·算法·自然语言处理