滑雪问题
来源:互联网 发布:网络会员制营销好处 编辑:程序博客网 时间:2024/05/21 15:40
滑雪问题是poj的一道中档难度题目:
Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你。Michael想知道载一个区域中最长底滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。下面是一个例子
1 2 3 4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。事实上,这是最长的一条。
现在需要找到一个给定山谷矩阵中的最长路径:很明显,找到最大点后,每一次找它周边最接近它且比它小的那个点;
这是我的Java寻找周围梯度点的程序段,可以较好处理边界特殊点:
</pre><pre name="code" class="java"> if (m_id-1>0){ FourPoints[0] = mountain[m_id-1][n_id]; } else {FourPoints[0] = -1;} if (m_id+1<m-1){ FourPoints[1] = mountain[m_id+1][n_id]; } else {FourPoints[1] = -1;} if (n_id-1>0){ FourPoints[2] = mountain[m_id][n_id-1]; } else {FourPoints[2] = -1;} if (n_id+1<n-1){ FourPoints[3] = mountain[m_id][n_id+1]; } else {FourPoints[3] = -1;} int Max = FourPoints[0]; int NextMid[2] = [m_id-1,n_id] for(int element:FourPoints) { if (element>Max && Max<mountain[m_id][n_id]) { Max = element; } } if(Max == -1 || Max>mountain[m_id][n_id]){return false;} if(Max == FourPoints[0]){ return [m_id-1,n_id];} if(Max == FourPoints[1]){ return [m_id+1,n_id];} if(Max == FourPoints[2]){ return [m_id,n_id-1];} if(Max == FourPoints[3]){ return [m_id,n_id+1];}
0 0
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- 滑雪问题
- poj 1088 滑雪问题
- poj 1088 滑雪问题
- DFS 解 滑雪问题
- poj 1088 滑雪问题
- 滑雪问题 | DP
- POJ数字滑雪问题
- poj1088滑雪问题
- dp问题 滑雪
- 滑雪问题的几个解法
- Java NIO框架Netty教程(一) – Hello Netty
- OpenGL Projection Matrix
- java 比较两个日期之间的大小
- iOS 怎样实现最多保留n位小数
- Java设计模式之原型模式与深浅拷贝
- 滑雪问题
- 博弈,枚举必胜区间______A multiplication game( poj 2505)
- 第三方登陆的 逻辑图
- leetcode 176. Second Highest Salary
- Intellij Idea导入非maven Web项目时遇到lib目录冲突的问题
- IOS cocoapods的安装
- codeforces705B B. Spider Man
- CAGradientLayer的一些属性解析 - 游贤明
- 人眼相机