leetcode Jump Game I II 待续 贪心看不懂啊!!!!
下面是这两个题的解法:
参考博客:http://blog.csdn.net/loverooney/article/details/38455475
自己写的第一题(TLE):
#include<iostream>
#include<vector> using namespace std; bool canJump(vector<int>& nums)
{
int L = nums.size();
bool *flag = new bool[L];
for (int i = L - ; i >= ; i--)
{
int right = i + nums[i];
if (right >= L - )
flag[i] = true;
else
{
flag[i] = false;
for (int j = i + ;j<L&& j < i + nums[i]; j++)
{
if (flag[j] == true)
{
flag[i] = true;
break;
}
}
}
}
return flag[];
} int main()
{
vector<int> a = { , , , , };
cout << canJump(a) << endl;
}
贪心用step维护当前可到达的最远位置,每次的i必须在这个最远位置以内,假如不在就表明不能前进了return false。
代码:
#include<iostream>
#include<vector> using namespace std; bool canJump(vector<int>& nums)
{
int L = nums.size();
int step = ;
for (int i = ; i <= step; i++)
{
if (nums[i] + i > step)
step = nums[i] + i;
if (step >= L - )
return true;
}
return false;
} int main()
{
int a[] = { , , , , };
cout << canJump(vector<int>(a, a+)) << endl;
}
第二题:
BFS解法(MLE):
#include<vector>
#include<iostream>
#include<queue> using namespace std; typedef struct Node
{
int index;
int jumpNo;
Node(int index, int jumpNo) :index(index), jumpNo(jumpNo){};
}Node; // BFS
int jump(vector<int>& nums)
{
int i = ;
int L = nums.size();
queue<Node> que;
que.push(Node(i,));
while (!que.empty())
{
Node now = que.front();
que.pop();
for (i = now.index + ; i <= nums[now.index] + now.index; i++)
{
if (nums[i]+now.index >= L - )
{
return now.jumpNo+;
}
else
que.push(Node(i,now.jumpNo+));
}
}
return -;
} int main()
{
vector<int> a = { , , , , };
cout << jump(a) << endl;
}
自己写的也是MLE:
#include<iostream>
#include<vector>
#include<queue> using namespace std; typedef struct Node
{
int val; //从该节点能调到哪儿
int len; //该节点在第len跳被访问
int index; //当前节点的下标
Node(int val,int index, int len) :val(val), index(index),len(len){};
Node(){};
}Node; int jump(vector<int>& nums)
{
int L = nums.size();
Node* nodeArray = new Node[L];
for (int i = ; i < L; i++)
{
nodeArray[i].val = nums[i];
nodeArray[i].index = i;
nodeArray[i].len = ;
}
//vector<bool> visited(L,false);
queue<Node> visiteQueue;
nodeArray[].len = ;
visiteQueue.push(nodeArray[]);
while (!visiteQueue.empty())
{
Node temp = visiteQueue.front();
int index = temp.index;
int canStep = temp.val;
for (int i = index + ; i <= index + canStep; i++)
{
if (nodeArray[i].index+nodeArray[i].val>=L-)
{
return temp.len + ;
}
Node nextNode(nodeArray[i].val,nodeArray[i].index, temp.len + );
visiteQueue.push(nextNode);
}
visiteQueue.pop();
}
return false;
} int main()
{
vector<int> a = { ,,, , , ,,,,};
cout << jump(a) << endl;
}
内存不超的BFS:http://www.myext.cn/c/a_4468.html
动态规划解法(TLE):
#include<iostream>
#include<vector> using namespace std; int jump(vector<int>& nums)
{
int L = nums.size();
int *dp = new int[L];
dp[] = ;
for (int i = ; i < L; i++)
{
int min = INT_MAX;
for (int j = ; j < i; j++)
{
if (nums[j] + j >= i&&dp[j]+<min)
{
min = dp[j] + ;
}
}
dp[i] = min;
}
for (int i = ; i < L; i++)
cout << dp[i] << endl;
return dp[L - ];
} int main()
{
vector<int> a = { , , , , };
cout << jump(a) << endl;
}
贪心解法:
leetcode Jump Game I II 待续 贪心看不懂啊!!!!的更多相关文章
- Jump Game I&&II——入门级贪心算法
Jump Game I Given an array of non-negative integers, you are initially positioned at the first index ...
- LeetCode:Jump Game I II
Jump Game Given an array of non-negative integers, you are initially positioned at the first index o ...
- LeetCode Single Number I / II / III
[1]LeetCode 136 Single Number 题意:奇数个数,其中除了一个数只出现一次外,其他数都是成对出现,比如1,2,2,3,3...,求出该单个数. 解法:容易想到异或的性质,两个 ...
- [array] leetcode - 40. Combination Sum II - Medium
leetcode - 40. Combination Sum II - Medium descrition Given a collection of candidate numbers (C) an ...
- LeetCode 137. Single Number II(只出现一次的数字 II)
LeetCode 137. Single Number II(只出现一次的数字 II)
- LeetCode:路径总和II【113】
LeetCode:路径总和II[113] 题目描述 给定一个二叉树和一个目标和,找到所有从根节点到叶子节点路径总和等于给定目标和的路径. 说明: 叶子节点是指没有子节点的节点. 示例:给定如下二叉树, ...
- LeetCode:组合总数II【40】
LeetCode:组合总数II[40] 题目描述 给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candi ...
- 对于挑战书上的很久之前都看不懂的DP看懂的突破
突破一..牢记问题概念 并且牢记dp状态方程 突破二..一直有一个求和dp转化成O1dp递推的式子看不懂.. 看不懂的原因是..没有分清求和符号作用的范围 提醒:以后遇到求和符号一定明确其求和的式子的 ...
- QQ地图api里的 地址解析函数 看不懂 javascript_百度知道
QQ地图api里的 地址解析函数 看不懂 javascript_百度知道 QQ地图api里的 地址解析函数 看不懂 javascript 2011-09-18 12:18 匿名 ...
随机推荐
- Shiro-RememberMe
概述 认证和记住我 建议 身份验证相关 实现 如果要自己做RememeberMe,需要在登录之前创建Token:UsernamePasswordToken(用户名,密码,是否记住我),且调用 User ...
- js1
document.write('<h1>Hello World</h1>'); //写入网页 alert('Hello World'); console.log('Hello ...
- BZOJ4303:数列
浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html 题目传送门:https://lydsy.com/JudgeOnline ...
- fastjson --JSONObject 和JSONArray 转换
fastjson解析:resultValue=[ { "total": 1, "saleLists": [ ...
- 在Mac系统下如何恢复SourceTree全局忽略的文件
在家目录“~”下编辑 “.gitignore_global ” 文件即可:vim .gitignore_global
- OpenWrt添加启动脚本
1.在 /etc/init.d 目录下建立文件 vi silabs #!/bin/sh /etc/rc.common # Copyright (C) 2006 OpenWrt.org START=93 ...
- java添加背景图片
总结:我们通常实现添加背景图片很容易,但是再添加按钮组件就会覆盖图片.原因是: 有先后啊.setlayout();与布局有很大关系 请调试代码的时候,仔细揣摩.我晕了 还可以添加文本框,密码框 fra ...
- java中内部类的讲解
java中有一个内部类的概念,由于之前一直比较忙,没有单独拿出时间总结一下,今天我就把内部类的相关知识进行一下汇总,如果有不足之处,欢迎批评指正. 1)java内部类的概念. 在一个类的的 ...
- Oracle 设置主键自增长__Oracle
转自:https://yq.aliyun.com/ziliao/258074 如果想在Oracle数据库里实现数据表主键自增,我们似乎没有办法像MySql般直接定义列的属性来实现.不过对于这个数据库的 ...
- C语言学习笔记--指针和数组的关系
1.数组的本质 (1)数组是一段连续的内存空间 (2)数组的空间大小:sizeof(array_type)*array_size; (3)数组名可看做指向数组第一个元素的常量指针 (4)数组声明时编译 ...