hdu1078】的更多相关文章

首先是题目的意思: 从一个正方形的0,0点开始走,只能横着走,竖着走,最多走k步,下一个点的数一定要比当前这个点的值大,每走一步,就加上下一个点的数据,问数据最大能有多少. 首先遇到这种题目,走来走去的,一开始想到的是搜索,但是搜索我们搜的很多是路径,能走到那个点的最短路,但是这道题目不一样. 首先要注意的一点是,如果没有条件的搜索,那就是枚举.只有搜遍了才能得到最后的解. 1s题,只是搜的话肯定TLE了. 所以我们想到的自然就是dp了.dp的好处是什么?就是能减少不必要的搜索.用已知的结果减少…
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1078 题意:老鼠从(1.1)点出发,每次最多只能走K步,而且下一步走的位置的值必须必当前值大.求这些位置和的最大值. 思路:用搜索逐步找每个点能到达的最大值,也是子最优解到整体的最优解,dp思想. 下面AC代码: #include<iostream> #include<cstdio> #include<algorithm> #include<cstring…
http://acm.hdu.edu.cn/showproblem.php?pid=1078 题意:给出n*n的格子,每个各自里面有些食物,问一只老鼠每次走最多k步所能吃到的最多的食物 #include<iostream> #include<stdio.h> #include<string.h> using namespace std; ][],s[][]; ][]= {,,-,,,,,-}; int dfs(int x,int y) { ,xx,yy,ans; if(…
/* hdu 1078 QAQ记忆化搜索 其实还是搜索..因为里面开了一个数组这样可以省时间 (dp[x][y]大于0就不用算了直接返回值) */ #include<stdio.h> #include<string.h> #include<algorithm> using namespace std; int n,l; ][]; ][]; ,,-,}; ,,,-}; bool check(int x,int y) { &&x<n&&…
//Accepted 468 KB 812 ms //bfs+dp #include <cstdio> #include <cstring> #include <iostream> using namespace std; #include <queue> ; int map[imax_n][imax_n]; int dp[imax_n][imax_n]; bool vis[imax_n][imax_n]; ]={,,-,,,,,-}; int n; int…
题意:一张n*n的格子表格,每个格子里有个数,每次能够水平或竖直走k个格子,允许上下左右走,每次走的格子上的数必须比上一个走的格子的数大,问最大的路径和. 我一开始的思路是,或许是普通的最大路径和,只是多了可以一次走k个格子这个条件而已,终于能够水过了呢! 紧接着我发现,不止能向左和下走,还可以往回走!这就不能用 for(i=0;i<n;i++)  for(j=0;j<n;j++) 这样的两个循环 dp 掉整个图了,因为当我更新完后面的点可能又会走回来. 并想不到 DFS 的我想到了我是否可以…
Problem Description FatMouse has stored some cheese in a city. The city can be considered as a square grid of dimension n: each grid location is labelled (p,q) where 0 <= p < n and 0 <= q < n. At each grid location Fatmouse has hid between 0 a…
本题大意:在一个n * n的迷宫内进行移动,左上角为初始位置,每次可以走的步数不能超过m,并且每次走的方格上面的数字要大于前一次走的放个数字,不能走到格子外面,问如何能使得到的数字和最大. 本题思路:dfs记忆化搜即可. 参考代码: #include <iostream> #include <cstring> #include <algorithm> using namespace std; int n, m; ; ][] = {{,},{-,},{,},{,-}};…
FatMouse and Cheese Problem Description FatMouse has stored some cheese in a city. The city can be considered as a square grid of dimension n: each grid location is labelled (p,q) where 0 <= p < n and 0 <= q < n. At each grid location Fatmouse…
题意:给出n*n的格子,每个各自里面有些食物,问一只老鼠每次走最多k步所能吃到的最多的食物 这道题目,值得我记住它,re了n次,以前写搜索没有注意的一个小地方,导致re这么多次的 ac代码: #include<iostream> #include<stdio.h> #include<string.h> using namespace std; int dp[110][110],s[110][110]; int n,k,t[4][2]={1,0,-1,0,0,1,0,-1…