洛谷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;
}
相关推荐
漫随流水1 小时前
leetcode算法(111.二叉树的最小深度)
数据结构·算法·leetcode·二叉树
じ☆冷颜〃8 小时前
黎曼几何驱动的算法与系统设计:理论、实践与跨领域应用
笔记·python·深度学习·网络协议·算法·机器学习
数据大魔方9 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
POLITE39 小时前
Leetcode 23. 合并 K 个升序链表 (Day 12)
算法·leetcode·链表
楚来客9 小时前
AI基础概念之八:Transformer算法通俗解析
人工智能·算法·transformer
Echo_NGC223710 小时前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁10 小时前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划
橘颂TA10 小时前
【剑斩OFFER】算法的暴力美学——二进制求和
算法·leetcode·哈希算法·散列表·结构与算法
地平线开发者11 小时前
征程 6 | cgroup sample
算法·自动驾驶