html5 frog jump,frog-jump

https://leetcode.com/problems/frog-jump///受以下网页启发,用递归可行// https://discuss.leetcode.com/topic/59337/easy-version-java

public classSolution {

Map mp;private int[] stones;public boolean canCross(int[] s) {

stones=s;if (stones[1] != 1) {return false;

}if (stones.length < 3) {return true;

}

mp= newHashMap();

Set st= newHashSet();

st.add(1);

mp.put(1, st);for (int i=2; i

Set newst= newHashSet();boolean isNewst = false;for (int j=1; j

Object obj=mp.get(j);if (obj == null) {continue;

}

Set tmpst=(Set) obj;int dist = stones[i] -stones[j];for (int k=-1; k<=1; k++) {if (tmpst.contains(dist+k)) {

newst.add(dist);

isNewst= true;

}

}

}if(isNewst) {

mp.put(i, newst);

}

}if (mp.get(stones.length-1) != null) {return true;

}else{return false;

}

}

}/*// 以下解法复杂性太高

public class Solution {

private int[] stones;

public boolean canCross(int[] s) {

stones = s;

if (stones[1] != 1) {

return false;

}

if (stones.length < 3) {

return true;

}

return impl(1, 1);

}

boolean impl(int pos, int step) {

if (pos == stones.length - 1) {

return true;

}

for (int i=pos+1; i

int dist = stones[i] - stones[pos];

if (dist >= step - 1 && dist <= step + 1) {

if (impl(i, dist)) {

return true;

}

}

}

return false;

}

}*/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值