蓝桥杯2023(十四届)省赛——接龙数列(DP)

接龙数列(DP)

1.接龙数列 - 蓝桥云课 (lanqiao.cn)

琢磨半天,本来是开一个三维的,dp[i][j][k] 表示 前i个,以j为首项,k为尾项的最大子集个数,但是实际上用二维即可。想求的是删除个数,我们反向操作,计算选取个数,最后用总量-选取个数=删除个数。这样就转化成了背包问题了,只不过,这个背包,装的条件,有些奇奇怪怪?

我给大家打出来dp的实际情况,如下:


AC:

cpp 复制代码
//接龙数列
#include <iostream>
using namespace std;

//反向操作,删除个数=总数-获取个数
//本题要我们求,符合该规律的最大子集元素个数
const int N=1e5+2;
int dp[10]={0};	//dp[i][j]  表示前i个,j结尾的子集,最大元素个数 这里我们进行了删维 
int a[N]={0};

int max(int a,int b)
{
	return a>b?a:b;
}

int main()
{
	int n;
	cin>>n;
	string a;	//用string处理首项和尾项更容易
	for(int i=0;i<n;i++)
	{
		cin>>a;
		int last=a.back()-'0';
		int first=a.front()-'0';
		dp[last]=max(dp[first]+1,dp[first]);
		
//		for(int j=0;j<=9;j++)	cout<<dp[j]<<" ";	用来观察的
//		cout<<endl;
	}
	
	int ans=0;
	for(int i=0;i<=9;i++)
		ans=max(ans,dp[i]);
	cout<<n-ans;
	
	return 0;
 } 
相关推荐
Black蜡笔小新4 分钟前
自动化AI算法训练服务器/企业AI算力工作站DLTM重塑企业AI开发模式赋能企业智能转型
人工智能·算法·自动化
科研小白_7 分钟前
【第一期:MATLAB点云处理基础】LAS点云数据导入与可视化
算法
2zcode8 分钟前
基于Matlab不规则颗粒粒径周长面积测量及计数系统
开发语言·算法·matlab
renhongxia111 分钟前
开源大模型VS闭源大模型:2026年格局再梳理
深度学习·算法·语言模型·分类·开源
笨笨饿12 分钟前
#85_库函数开发
linux·c语言·网络·stm32·单片机·算法·个人开发
绛橘色的日落(。・∀・)ノ18 分钟前
深度学习 反向传播与计算图实验
算法
谙弆悕博士20 分钟前
Fortran学习笔记
经验分享·笔记·学习·职场和发展·跳槽·学习方法·fortran
Tisfy20 分钟前
LeetCode 1914.循环轮转矩阵:大模拟(数组原地轮转) —— 附O(1)空间版本
算法·leetcode·矩阵·大模拟
Hello.Reader24 分钟前
算法基础(三)—— 插入排序从整理扑克牌到有序数组
java·算法·排序算法
50万马克的面包25 分钟前
C语言:三大基础排序算法模板 冒泡 / 选择 / 插入)
c语言·笔记·算法·排序算法