滑雪
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 73694 | Accepted: 27250 | 
Description
Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激。可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你。Michael想知道载一个区域中最长底滑坡。区域由一个二维数组给出。数组的每个数字代表点的高度。下面是一个例子 
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。事实上,这是最长的一条。
1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9
一个人可以从某个点滑向上下左右相邻四个点之一,当且仅当高度减小。在上面的例子中,一条可滑行的滑坡为24-17-16-1。当然25-24-23-...-3-2-1更长。事实上,这是最长的一条。
Input
输入的第一行表示区域的行数R和列数C(1 <= R,C <= 100)。下面是R行,每行有C个整数,代表高度h,0<=h<=10000。
Output
输出最长区域的长度。
Sample Input
5 5 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9
Sample Output
25
题意:找最长的滑行距离。
思路:将高度从小到大排,那么它周围比它高的点的滑行距离就是max(num[i-1][j],num[i][j]+1)。BFS会超时。
AC代码如下:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int high[110][110];
int num[110][110],n,m,ans=0;
struct node
{ int x,y,h;
} dian[10010];
bool cmp(node a,node b)
{ return a.h<b.h;
}
void solve(int pos)
{ int i=dian[pos].x,j=dian[pos].y;
  if(high[i-1][j]>high[i][j])
   num[i-1][j]=max(num[i-1][j],num[i][j]+1);
  if(high[i+1][j]>high[i][j])
   num[i+1][j]=max(num[i+1][j],num[i][j]+1);
  if(high[i][j-1]>high[i][j])
   num[i][j-1]=max(num[i][j-1],num[i][j]+1);
  if(high[i][j+1]>high[i][j])
   num[i][j+1]=max(num[i][j+1],num[i][j]+1);
}
int main()
{ int i,j,h,t=0;
  scanf("%d%d",&n,&m);
  for(i=1;i<=n;i++)
   for(j=1;j<=m;j++)
   { scanf("%d",&h);
     dian[++t].x=i;
     dian[t].y=j;
     dian[t].h=h;
     high[i][j]=h;
   }
  sort(dian+1,dian+1+t,cmp);
  for(i=1;i<=t;i++)
   solve(i);
  for(i=1;i<=n;i++)
   for(j=1;j<=m;j++)
    if(num[i][j]>ans)
     ans=num[i][j];
  ans++;
  printf("%d\n",ans);
}
 
                   
                   
                   
                   
                            
 
                             本文探讨了如何在给定的二维数组地形中找到最长的滑雪滑行路线,通过将高度排序并应用特定算法实现这一目标。
本文探讨了如何在给定的二维数组地形中找到最长的滑雪滑行路线,通过将高度排序并应用特定算法实现这一目标。
           
       
           
                 
                 
                 
                 
                 
                
               
                 
                 
                 
                 
                
               
                 
                 扫一扫
扫一扫
                     
              
             
                   912
					912
					
 被折叠的  条评论
		 为什么被折叠?
被折叠的  条评论
		 为什么被折叠?
		 
		  到【灌水乐园】发言
到【灌水乐园】发言                                
		 
		 
    
   
    
   
             
            


 
            