【动态规划】【递归】取数字问题 (ssl 1644)

取数字问题取数字问题

Description

给定M*N的矩阵,其中的每个元素都是-10到10之间的整数。你的任务是从左上角(1,1)走到右下角(M,N),每一步只能向右或向下,并且不能走出矩阵的范围。你所经过的方格里面的数字都必须被选取,请找出一条最合适的道路,使得在路上被选取的数字之和是尽可能小的正整数。

Input

第一行两个整数M,N,(2<=M,N<=10),分别表示矩阵的行和列的数目。

接下来的M行,每行包括N个整数,就是矩阵中的每一行的N个元素。

Output

仅一行一个整数,表示所选道路上数字之和所能达到的最小的正整数。如果不能达到任何正整数就输出-1。

Sample Input

2 2

0 2

1 0

Sample Output

1

题目大意:

有一个n*m的矩阵,每个位置都有一个-10~10的分数(每走到一个位置,就会自动得到当前位置的分数),要从(1,1)走到(n,m),要使分数是正整数,并且最小,若结果都非正整数,输出-1

方法一方法一

解题方法:

先枚举一个i(结果),然后从(n,m)dfs到(1,1),使当前值为上一个f(存结果)减去当前的a(本来的数值),当(1,1)为0时,就是可以从(n,m)到(1,1),否则枚举下一个a,因为有负数所以存的时候要加一个M(我写的是1001)

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
#define M 1001
using namespace std;
int ans,n,m,a[15][15],f[15][15][M*2];
void dfs(int x,int y,int d)//x,y为行列,d为当前数
{f[x][y][d+M]=1;if (f[1][1][M]) return;if ((x>1)&&(!f[x-1][y][d-a[x-1][y]+M])) dfs(x-1,y,d-a[x-1][y]);//往上,要先判断是否越界,是否走过同样的数,如果走了同样的数就会浪费时间if ((y>1)&&(!f[x][y-1][d-a[x][y-1]+M])) dfs(x,y-1,d-a[x][y-1]);//往左,要先判断是否越界,是否走过同样的数,如果走了同样的数就会浪费时间
}
int main()
{ans=-1;scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)for (int j=1;j<=m;j++)scanf("%d",&a[i][j]);//输入for (int i=1;i<=n*m*10;i++)//枚举结果{dfs(n,m,i-a[n][m]);//最后一个要先减去它的a值if (f[1][1][M]) //如果有结果就记录,break{ans=i;break;}}printf("%d",ans);
}

方法二方法二

用DP的方法,用一个数组f[i][j][k]来表示第i行第j列是否能得到数字k,但k是已经加了一个M(我写的是1001)的,所以在输出时要从M+1开始

动态转移方程:

{if(f[i−1][j][k])f[i][j][k+a[i][j]]=1if(f[i][j−1][k])f[i][j][k+a[i][j]]=1\left\{\begin{matrix}if(f[i-1][j][k]) & f[i][j][k+a[i][j]]=1\\ if (f[i][j-1][k]) & f[i][j][k+a[i][j]]=1\end{matrix}\right.{if(f[i1][j][k])if(f[i][j1][k])f[i][j][k+a[i][j]]=1f[i][j][k+a[i][j]]=1

解释:

第一行的为取上的数,第二行的为取上的数

程序解析待续…

#include<cstdio>
#include<iostream>
#include<cstring>
#include<string>
#define M 1001
using namespace std;
int a[15][15],f[15][15][M*2+5],n,m,t;
int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)for (int j=1;j<=m;j++)scanf("%d",&a[i][j]);f[1][1][a[1][1]+M]=1;//(1,1)的值初始化为自己的值t=a[1][1]+M;//存好,后面要用for (int i=2;i<=n;i++)//第一列下去f[i][1][t+a[i][1]]=1,t+=a[i][1];//t为前面的值,加上当前的值,再赋值1,表示有这个数;后面一句是为了方便后面求值t=a[1][1]+M;//再存,后面还要用for (int j=2;j<=m;j++)//第一行f[1][j][t+a[1][j]]=1,t+=a[1][j];//同上for (int i=2;i<=n;i++)//行for (int j=2;j<=m;j++)//列for (int k=1;k<=M*2;k++)//上一个的数字{if (f[i-1][j][k]) f[i][j][k+a[i][j]]=1;//动态转移方程if (f[i][j-1][k]) f[i][j][k+a[i][j]]=1;//动态转移方程}int k=M+1;//因0~M-1是负数,M是0(提前加过了),所以从M+1开始while ((!f[n][m][k])&&(k<=M*2)) k++;//求最小,第二个判定是为了不出界if (k<=M*2) printf("%d",k-M);//如果大于M*2就说明无解else printf("-1");
}

方法三方法三

直接相加,用一个三位数组f,f[i][j][0]表示第i行第j列有多少个数字,之后的f[i][j][k]表示他的数字

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int a[11][11],n,m,ans,f[11][11][50000];
int main()
{scanf("%d%d",&n,&m);for (int i=1;i<=n;i++)for (int j=1;j<=m;j++)scanf("%d",&a[i][j]);f[1][1][0]=1;//初始化f[1][1][1]=a[1][1];//初始化for (int i=2;i<=n;i++)f[i][1][1]=f[i-1][1][1]+a[i][1],f[i][1][0]=1;//第一列for (int i=2;i<=m;i++)f[1][i][1]=f[1][i-1][1]+a[1][i],f[1][i][0]=1;//第一行for (int i=2;i<=n;i++)for (int j=2;j<=m;j++){f[i][j][0]=f[i-1][j][0]+f[i][j-1][0];//数字个数为上面数字个数加左边数字个数for (int k=1;k<=f[i-1][j][0];k++)f[i][j][k]=f[i-1][j][k]+a[i][j];//直接加for (int k=1;k<=f[i][j-1][0];k++)f[i][j][k+f[i-1][j][0]]=f[i][j-1][k]+a[i][j];//不能覆盖,要再加上f[i-1][j][0]}ans=2147483647;//因为要求最小,所以要赋一个大的值for (int i=1;i<=f[n][m][0];i++)if (f[n][m][i]>0)//排除负数和0ans=min(ans,f[n][m][i]);if (ans==2147483647) printf("-1");//如果没有改变,输出-1else printf("%d",ans);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321413.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

9、mybatis中动态sql的使用

对于初学者&#xff0c;如何进行mybatis的学习呢&#xff1f;我总结了几点&#xff0c;会慢慢的更新出来。首先大家需要了解mybatis是什么、用mybatis来做什么、为什么要用mybatis、有什么优缺点&#xff1b;当知道了为什么的时候就开始了解如何用的问题&#xff0c;如何使用my…

软件质量保证划重点期末复习总结

软件质量保证复习总结大纲及问题 Module1 《软件工程实践》 1、软件工程实践通过解决问题的根源来指导软件开发。 2、软件工程实践之间相辅相成。 3、过程指导一个团队在什么时候做什么以及如何做。 4、软件工程过程为实现软件工程实践提供了上下文和支持。 Module2 《软件…

P4721-[模板]分治FFT【NTT,分治】

正题 题目链接:https://www.luogu.com.cn/problem/P4721 题目大意 给出序列ggg&#xff0c;然后f01f_01f0​1 fi∑j1ifi−jgjf_{i}\sum_{j1}^if_{i-j}g_jfi​j1∑i​fi−j​gj​ 求序列fff 解题思路 使用分治后用NTTNTTNTT计算前区间对后区间的贡献即可。 时间复杂度O(nlo…

Microsoft Build 2018 直播来啦!

一年一度的Microsoft Build大会又来啦&#xff01;Microsoft Build是微软面向全球开发者、合作伙伴以及消费者介绍其重要产品在未来一年内发展方向的技术盛会。而今年的Microsoft Build 2018大会是微软巨大蜕变、最彻底组织变革后的第一次前沿技术大会。更多了解&#xff0c;请…

【动态规划】矩阵链相乘 (ssl 1596)/能量项链 (ssl 2006)

矩阵链相乘{\color{Cyan} 矩阵链相乘 }矩阵链相乘 Description Input n表示矩阵的个数(<100) n1个数,表示矩阵(<100) Output 最小的乘法次数 Sample Input 5 5 10 4 6 10 2 Sample Output 348 题目大意&#xff1a; 有n个矩阵&#xff0c;输入n1个数&#x…

10、mybatis中缓存的使用

对于初学者&#xff0c;如何进行mybatis的学习呢&#xff1f;我总结了几点&#xff0c;会慢慢的更新出来。首先大家需要了解mybatis是什么、用mybatis来做什么、为什么要用mybatis、有什么优缺点&#xff1b;当知道了为什么的时候就开始了解如何用的问题&#xff0c;如何使用my…

C#编译器优化那点事

使用C#编写程序&#xff0c;给最终用户的程序&#xff0c;是需要使用release配置的&#xff0c;而release配置和debug配置&#xff0c;有一个关键区别&#xff0c;就是release的编译器优化默认是启用的。优化代码开关即optimize开关&#xff0c;和debug开关一起&#xff0c;有以…

P3195-[HNOI2008]玩具装箱【斜率优化dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3195 题目大意 nnn个物品&#xff0c;分成若干段&#xff0c;每一段的长度为j−i∑ilrCkj-i\sum_{il}^rC_kj−i∑ilr​Ck​&#xff0c;打包价格为(长度−L)2(长度-L)^2(长度−L)2 求最小价格和。 解题思路 si∑j1iCjs_i\su…

【动态规划】书的复制 (ssl 1203)

书的复制书的复制书的复制 Description 现在要把m本有顺序的书分给k个人复制&#xff08;抄写&#xff09;&#xff0c;每个人的抄写速度都一样&#xff0c;一本书不允许分给两个或两个以上的人抄写&#xff0c;分给每个人的书&#xff0c;必须是连续的&#xff0c;比如不能把…

P1975-[国家集训队]排队【树状数组套线段树】

正题 题目链接:https://www.luogu.com.cn/problem/P1975 题目大意 一个nnn个数字的序列&#xff0c;每次交换两个数&#xff0c;求逆序对。 解题思路 显然交换lll和rrr的话对[1..l−1][1..l-1][1..l−1]和[r1,n][r1,n][r1,n]是不会有影响的&#xff0c;所以我们只需要考虑ll…

【动态规划】分组背包 (ssl 2291)

分组背包分组背包分组背包 Description 有N件物品和一个容量为V的背包。第i件物品的费用是c[i]&#xff0c;价值是w[i]。这些物品被划分为若干组&#xff0c;每组中的物品互相冲突&#xff0c;最多选一件。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量&#…

如何在Visual Studio 2017中使用C# 7+语法

前言之前不知看过哪位前辈的博文有点印象C# 7控制台开始支持执行异步方法&#xff0c;然后闲来无事&#xff0c;搞着&#xff0c;搞着没搞出来&#xff0c;然后就写了这篇博文&#xff0c;不喜勿喷&#xff0c;或许对您有帮助。在Visual Studio 2017配置支持C# 7语法心想都VS20…

11、mybatis的功能架构分析

1、Mybatis功能架构 1&#xff09;API接口层&#xff1a;提供给外部使用的接口API&#xff0c;开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。 2&#xff09;数据处理层&#xff1a;负责具体的SQL查找、SQL解析、SQL执…

我的ACM之路-写于南宁站后

先说说我的ACM之路吧。自大一下学期开学开始&#xff0c;受到OI大佬舍友的影响&#xff0c;遂入坑。开始啃白书和紫书&#xff0c;然而发现好难啊。意识到大概是自己算法和数据结构知识欠缺的太厉害了&#xff0c;于是去网上买了本数据结构的教材&#xff08;隐约记得是清华大学…

P1903-[国家集训队]数颜色/维护队列【带修莫队】

正题 题目链接:https://www.luogu.com.cn/problem/P1903 题目大意 要求支持两个操作 QLR:Q\ \ L\ \ R:Q L R:询问L,RL,RL,R之间有多少个不同的数RPCol:R\ \ P\ \ Col:R P Col:将PPP修改为ColColCol 解题思路 莫队中多加一个时间维度ttt表示前面有多少个修改操作&#xf…

【动态规划】方格取数 (ssl 1010)

方格取数方格取数方格取数 Description 设有N*N的方格图(N<10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。如下图所示&#xff08;见样例&#xff09;&#xff1a; 某人从图的左上角的A 点出发&#xff0c;可以向下行走&#xff0c;也可以向右走&#…

ASP.NET Core 使用UrlFirewall对请求进行过滤

一. 前言UrlFirewall 是一个开源、轻便的对http请求进行过滤的中间件&#xff0c;可使用在webapi或者网关&#xff08;比如Ocelot&#xff09;,由我本人编写&#xff0c;并且开源在github&#xff1a;https://github.com/stulzq/UrlFirewall 欢迎star.二.UrlFirewall 介绍UrlFi…

1、设计模式和原则总述

目录 一、什么是设计模式&#xff1f;有什么用&#xff1f; 二、设计模式 三、设计原则 一、什么是设计模式&#xff1f;有什么用&#xff1f; 设计模式是一套代码设计的经验总结&#xff0c;使用设计模式可以提高代码的重用性、可靠性&#xff0c;提交代码内聚&#xff0c;降…

P3600-随机数生成器【dp,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/P3600 题目大意 nnn个数的序列&#xff0c;每个数是[1..x][1..x][1..x]中的一个&#xff0c;有qqq个区间[l..r][l..r][l..r]&#xff0c;求所有区间最小值的最大值的期望。 解题思路 首先如果一个区间包含别的区间&#xff0…

Visual Studio 15.7预览版4改进Git、C++支持

对于即将到来的Visual Studio 2017 15.7&#xff0c;微软已经发布了多个新的预览版本。这些版本的变更很有限&#xff0c;似乎离正式发布不远了。通常&#xff0c;变更的涉及面很广——因此&#xff0c;不管是用什么语言&#xff0c;开发人员都可以看到一些好处。第一次&#x…