滑雪问题 | DP

问题:

见POJ1088 http://poj.org/problem?id=1088

php解法: 参考:http://poj.org/showmessage?message_id=118838

<?php
/*
 * @url: http://poj.org/showmessage?message_id=118838
 * DP(i,j) = max( DP(i,j-1), DP(i,j+1), DP(i-1,j), DP(i+1,j) ) + 1;
 */

$row = 4;
$col = 5;
$max_len_route = array();
$route = array
(
	array(1,2,3,4,5),
	array(14,15,16,17,6),
	array(13,20,19,18,7),
	array(12,11,10,9,8)
);

function skiing($i,$j) {
	$max = 0;
	global $max_len_route;
	global $row,$col;
	global $route;
     	if(isset($max_len_route[$i][$j]) && $max_len_route[$i][$j] > 0) {
		return $max_len_route[$i][$j];
	}
	//up
	if($i > 0 && $route[$i][$j] > $route[$i-1][$j] && $max < skiing($i-1,$j)) {
		$max = skiing($i-1,$j);
	}
	//down
	if($i < ($row-1) && $route[$i][$j] > $route[$i+1][$j] && $max < skiing($i+1,$j)) {
		$max = skiing($i+1,$j);
	}
	//left
	if($j > 0 && $route[$i][$j] > $route[$i][$j-1] && $max < skiing($i,$j-1)) {
		$max = skiing($i,$j-1);
	}
	//right
	if($j < ($col-1) && $route[$i][$j] > $route[$i][$j+1] && $max < skiing($i,$j+1)) {
		$max = skiing($i,$j+1);
	}
	
	$max_len_route[$i][$j] = $max + 1;
	return $max_len_route[$i][$j];
}

$maxlen = 0;

for($i = 0; $i < $row; $i++){
	for($j = 0; $j < $col; $j++) {
		$temp = skiing($i,$j);
		var_dump($temp);
		if($temp > $maxlen) {
			$maxlen = $temp;
		}
	}
}

printf("The max length route is: %d",$maxlen);
?>


输出:


thanks buptpatriot!

PS:上述方法的执行速度很慢,尚需改进。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值