首页 > 其他分享 >做题小结 dp训练3

做题小结 dp训练3

时间:2024-08-09 21:28:05浏览次数:6  
标签:可行 训练 int 然后 就是 思考 小结 dp

第一个

这道题 主要思考到一个不可以连续两步 以及最大往左移动5位 就像背包一样
所以我们开个二维的dp数组表示

	for (int j = 1; j <=z ; j++) {
			if (i + j *2<= k + 1 &&i-1>=1) {
				dp[i][j] = max(dp[i][j - 1] + a[i - 1] + a[i], max(dp[i][j],dp[i-1][j]+a[i]));
			}
		}

注意到往左j步 产生回来的话就是j*2 然后这个就是一个边界条件判断
别的就没啥了 挺好的一道题目

题目-字符串蓝题

这个题有点狗屎 要求挺多的 又要连着头尾 又要最后一样

不过我没想到最后一样这个其实不就是只输出dp[i][i]就行了

然后头尾其实就是二维表示下即可 dp[i][j]表示i开头j结尾的
然后就是一个状态转移方程

提取这个字符串的头尾
dp[i][j]=max(dp[i][j],dp[i][newt]+len)即可 这个j也是新的字符串的尾巴

然后注意dp[newt][neww]=len 记得赋值下就可以了

for(int i=1;i<=n;i++)
	{
		cin>>x;
	  int g=x[0]-'a'+1;
		int gg=x[x.size()-1]-'a'+1;
		int w=x.size();
		for(int j=1;j<=26;j++)
		{
			if(dp[j][g])
			dp[j][gg]=max(dp[j][gg],dp[j][g]+w);
		}
		dp[g][gg]=max(dp[g][gg],w);	
	}

这个题 一开始题目读错了 后面才知道 翻转就行

我还以为是这样的操作 只能对位反转 给我思考了半天

然后其实就没什么了 四个情况 一一对应就好了 这边不列举了

树形

不错的一道好题
我写了个dfs。。。直接t飞了 我知道会t的。。。

后面思考正解 考虑dp二维表示可行不可行

反正最终答案一定是n对吧
我老是想说一件事情 就是写dp题要有一种大局观 就是上帝视角一样
有一种不拘泥小节的思想 看事情看的很远的视野

这个题就体现的很好

就像背包一样
我们开一层循环1-n 第二层表示 走到i的方式当然要取min k

其实就是个背包这个题。。。。

然后可行的就是j>=d的

状态转移
j>=d:
对于可行可以由可行与不可行转移过来
j<d
不可行呢 不可行不是说我不能从可行转移过来 那如果我之前选了d 此次我选的挺小的 就必须保存答案呀


  for(int i=1;i<=n;i++)
	 {
		 for(int j=1;j<=min(k,i);j++)
		 {
			 if(j>=d)
			 {
			dp[i][1]+=dp[i-j][0]+dp[i-j][1];
				 dp[i][1]%=mod;
			 }
			 else {
			dp[i][1]+=dp[i-j][1];
				 dp[i][1]%=mod;
			dp[i][0]+=dp[i-j][0];	 
				 dp[i][0]%=mod;
			 }
		 }
	 }

好题

你可以最多进行 k 次如下的操作:选择两个正整数i,x,使 ai 变成
ai+ai/x 这一步很帅 观察到n只有1000
考虑n方dp 当然你问我n大了怎么办
我也不会。。。这个dp也是很有技巧的 非常的帅
如果n大了其实你会发现到很多的j都是无用的 我想 优化的话应该要用到整除分块的思想 具体我就不知道怎么了 毕竟整除分块都是蓝模板了
跑最短路做不了的 边都建不了
然后dp写完之后 最主要还是要发现k是诈骗 实际上1e3的数据撑不了几十次 所以k多了就是浪费 所以我们太大的k直接输出就行

状态压缩dp

这个题 我思考错了 我也想了一个512*n的做法 不过 我后面就思考到了
还是那句话 没有全局观 其实dp数组交代不清楚

/	for (int i = 3; i <= n; i++) {
//		int temp = now;
//		bool flag = 0;
//			for (int k = 0; k <= 520; k++) {
//				if ( dp[i][k] && !flag) {
//					now =  k | temp;
//					flag = 1;
//				}
//				else if (dp[i][k] && flag)
//					now = min(now, k | temp);
//			}	

这里的dp数组是那个到i可以成多少的意思 然后就可以了
这种dp开法也是很常见的 说实话

	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
		int w=a[i]&b[j];
		for(int k=0;k<=512;k++)
		dp[i][k|w]|=dp[i-1][k];			
		}
	}

标签:可行,训练,int,然后,就是,思考,小结,dp
From: https://www.cnblogs.com/LteShuai/p/18351525

相关文章

  • *算法训练(leetcode)第四十七天 | 并查集理论基础、107. 寻找存在的路径
    刷题记录*并查集理论基础107.寻找存在的路径*并查集理论基础讲解107.寻找存在的路径题目地址直接套模板。结点编号从1开始,因此定义father数组时需要n+1个空间,否则会越界。时间复杂度:O(......
  • SSD训练细节
    sampling·pyimportrandomimporttorchimporttorch.nnasnnfromtorch.autogradimportVariablefromtorch.autogradimportFunctionfrombboximportbboxIOU__all__=["buildPredBoxes","sampleEzDetect"]defbuildPredBoxes(config)......
  • dp套dp
    我们先说一下\(dp\)套\(dp\)大概是个什么东西。感性理解一些,你现在有一个动态规划数组\(g\),然后你的\(f\)用\(g\)的某种方式作为下标进行转移。事实上,这个\(g\)需要满足单调性,然后相当于你是在一个\(DAG\)上做\(dp\)。为什么要满足单调性,否则有可能出现环,有环代表......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-08 仿真验证
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! 4仿真验证仿真代码的顶层如下......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-09 ICMP层程序设计
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! 5上板调试5.1硬件连接本次......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-04 IP层程序设计
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! 3.3IP层ICMP层数据和UDP层数......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-05 ARP层程序设计
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑 3.4ARP层该层具有接收ARP请求......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-06 UDP层程序设计
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! 3.5UDP层该层实现用户数据和U......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-07 ICMP层程序设计
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! 3.6ICMP层该层在程序中为IP层......
  • [米联客-安路飞龙DR1-FPSOC] UDP通信篇连载-01 以太网协议介绍
    软件版本:Anlogic-TD5.9.1-DR1_ES1.1操作系统:WIN1064bit硬件平台:适用安路(Anlogic)FPGA实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板板卡获取平台:https://milianke.tmall.com/登录"米联客"FPGA社区http://www.uisrc.com视频课程、答疑解惑! ​1概述本文介绍了基于XILIN......