算法练习LeetCode初级算法之动态规划
爬楼梯:斐波那契数列
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
注意:给定 n 是一个正整数。
非递归解法
class Solution {
public int climbStairs(int n) {
if (n==1) {
return 1;
}
if (n==2) {
return 2;
}
int n1=1,n2=2;
for (int i = 0; i <n-2; i++) {
int m=n1+n2;
n1=n2;
n2=m;
}
return n2;
}
}
递归解法
class Solution {
int[] result=null;
public int climbStairs(int n) {
result=new int[n+1];
Arrays.fill(result, -1);
f(n);
return result[n];
}
private void f(int X) {
if (result[X]!=-1) {
return;
}
if (X==0||X==1) {
result[X]=1;
return;
}
f(X-1);
f(X-2);
result[X]=result[X-1]+result[X-2];
}
}
买卖股票的最佳时机
重点是要设置一个最小值和一个最大值,并且不断替换!
class Solution {
public int maxProfit(int[] prices) {
if (prices.length==0||prices.length==1) {
return 0;
}
int minPrice=prices[0];
int maxPrice=0;
for (int i = 0; i < prices.length; i++) {
if (prices[i]<=minPrice) {
minPrice=prices[i];
}else if ((prices[i]-minPrice)>maxPrice) {
maxPrice=prices[i]-minPrice;
}
}
return maxPrice;
}
}
最大子序和
超出时间限制的解法
class Solution {
public int maxSubArray(int[] nums) {
if (nums.length==0) {
return 0;
}
if (nums.length==1) {
return nums[0];
}
int sum=0;
Set<Integer> list=new TreeSet<>();
int n=1;
while (n<=nums.length) {
for (int i = 0; i < nums.length-n+1; i++) {
int m=0;
for (int j = 0; j < n; j++) {
m+=nums[i+j];
}
list.add(m);
}
n++;
}
int res=0;
for (Iterator iterator = list.iterator(); iterator.hasNext();) {
res= (Integer) iterator.next();
}
return res;
}
}
优化解法
没想到可以这样解,厉害!找个例子试一试就懂了
class Solution {
public int maxSubArray(int[] nums)
{
if (nums.length==0) {
return 0;
}
if (nums.length==1) {
return nums[0];
}
int max=nums[0];
int sum=0;
for (int i = 0; i < nums.length; i++) {
if (sum>0) {
sum+=nums[i];
}else {
sum=nums[i];
}
max=Math.max(max, sum);
}
return max;
}
}
更简单的解法:找最大子序列,最重要的要分清正负!!!
class Solution {
public int maxSubArray(int[] nums)
{
int max=nums[0];
int sum=nums[0];
for (int i = 1; i < nums.length; i++) {
sum=Math.max(sum+nums[i], nums[i]);
max=Math.max(max, sum);
}
return max;
}
}
打家劫舍
挺难的,参考别人的解法,先记住
递归法
class Solution {
//测试2,1,1,2
private int[] memo;
public int rob(int[] nums) {
memo=new int[nums.length];
Arrays.fill(memo, -1);
return tryRob(nums, 0);
}
private int tryRob(int[] nums,int index) {
if (index>=nums.length) {
return 0;
}
if (memo[index]!=-1) {
return memo[index];
}
int res=0;
for (int i = index; i < nums.length; i++) {//循环每次后移,即可以跳过(相隔)两个或多个
res=Math.max(res, nums[i]+tryRob(nums,i+2));
}
memo[index]=res;
return res;
}
}
动态规划
class Solution {
//测试2,1,1,2
public int rob(int[] nums) {
int n = nums.length;
if (n == 0) {
return 0;
}
if (n==1) {
return nums[0];
}
if (n==2) {
return Math.max(nums[0], nums[1]);
}
int[] f = new int[n];
f[0]=nums[0];
f[1]=Math.max(nums[0], nums[1]);//典型动态规划问题,先将子问题记录,然后
for (int i = 2; i < f.length; i++) {
f[i]=Math.max(f[i-2]+nums[i], f[i-1]);//这里利用子问题来解决问题
}
return f[n-1];
}
}
参考:https://blog.csdn.net/likunkun__/article/details/80724683
算法练习LeetCode初级算法之动态规划的更多相关文章
- 【LeetCode算法】LeetCode初级算法——字符串
在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...
- 算法练习LeetCode初级算法之链表
删除链表中的节点 /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode ne ...
- 算法练习LeetCode初级算法之字符串
反转字符串 我的解法比较low,利用集合的工具类Collections.reverse反转,用时过长 class Solution { public void reverseString(char[] ...
- 算法练习LeetCode初级算法之数组
删除数组中的重复项 官方解答: 旋转数组 存在重复元素 只出现一次的数 官方解答: 同一个字符进行两次异或运算就会回到原来的值 两个数组的交集 II import java.util.Arr ...
- 算法练习LeetCode初级算法之其他
位1的个数 解法一: class Solution { // you need to treat n as an unsigned value public int hammingWeight(int ...
- 算法练习LeetCode初级算法之数学
Fizz Buzz class Solution { public List<String> fizzBuzz(int n) { List<String> list=new L ...
- 算法练习LeetCode初级算法之设计问题
打乱数组 不断的让第一个与后面随机选择的数交换 class Solution { private int[] nums; private int[] initnums; public Solution ...
- 算法练习LeetCode初级算法之排序和搜索
合并两个有序数组 class Solution { public void merge(int[] nums1, int m, int[] nums2, int n) { System.arrayco ...
- 算法练习LeetCode初级算法之树
二叉树的前序遍历 我的解法:利用递归,自底向下逐步添加到list,返回最终的前序遍历list class Solution { public List<Integer> preorderT ...
随机推荐
- oracle dg 报错提示 涉及硬盘错误
###oracle dg 报错提示 涉及硬盘错误 Dec 23 03:28:01 xhisdg rsyslogd: [origin software="rsyslogd" swVe ...
- 20175311 2018-2019-2 《Java程序设计》第7周学习总结
20175311 2018-2019-2 <Java程序设计>第7周学习总结 教材学习内容总结 这一周我主要学习了第八章的内容-常用实用类String类 构造String对象 字符串的并置 ...
- DATA 步数据纵向串接
DATA A;A='1';RUN; %MACRO M_A();DATA B;SET %DO I=1 %TO 10;A%END;;RUN;%MEND; %M_A(); PROC PRINT DATA=B ...
- java中抽象类是否可以继承实体类?
一道java 常见面试题,网上找到的几乎每个 java 面试笔试题大全或集锦里都能找到这道题. 题目如下:问: 抽象类是否可继承实体类 (concrete class) 答: 抽象类是可以继承实体类, ...
- Avalon MM 总线
对于Avalon Master来讲,Address信号代表一个字节(8-bit)的地址.Address的值必须与字节的宽度对齐,如果要对某个word的byte写,需要首先使用byteenable信号: ...
- Java 公平锁与非公平锁学习研究
最近学习研究了一下Java中关于公平锁与非公平锁的底层实现原理,总结了一下. 首先呢,通过其字面意思,公平与非公平的评判标准就是付出与收获成正比(和社会中的含义差不多一个意思).放到程序中,尤其是 在 ...
- HttpClient 302重定向
CloseableHttpClient是线程安全的,单个实例可用于处理多个HTTP请求,Http Client会自动处理所有的重定向,关闭自动重定向需要设定disableAutomaticRetrie ...
- Sublime Text3使用Package Control 报错There Are No Packages Available For Installation
转 http://blog.csdn.net/feilong_csdn/article/details/67638660 在使用sublime时,有时候我们希望将代码复制出来后仍然是高亮显示,这样我们 ...
- Maven 错误 :The POM for com.xxx:jar:0.0.1-SNAPSHOT is invalid, transitive dependencies (if any) will not be available
一个大的maven 项目,结构是一个根pom,下面几个小的module,包括了appservice-darc,appservice-entity等,其中appservice-darc 依赖了 apps ...
- 树——B-树
B树的定义: 1.若根结点不是终端结点,则至少有2棵子树 2.每个中间节点都包含k-1个元素和k个孩子,其中 m/2 <= k <= m 3.每一个叶子节点都包含k-1个元素,其中 m/2 ...