• 爬楼梯:斐波那契数列

    假设你正在爬楼梯。需要 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初级算法之动态规划的更多相关文章

  1. 【LeetCode算法】LeetCode初级算法——字符串

      在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...

  2. 算法练习LeetCode初级算法之链表

    删除链表中的节点 /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode ne ...

  3. 算法练习LeetCode初级算法之字符串

    反转字符串 我的解法比较low,利用集合的工具类Collections.reverse反转,用时过长 class Solution { public void reverseString(char[] ...

  4. 算法练习LeetCode初级算法之数组

    删除数组中的重复项 官方解答: 旋转数组 存在重复元素 只出现一次的数     官方解答:  同一个字符进行两次异或运算就会回到原来的值 两个数组的交集 II import java.util.Arr ...

  5. 算法练习LeetCode初级算法之其他

    位1的个数 解法一: class Solution { // you need to treat n as an unsigned value public int hammingWeight(int ...

  6. 算法练习LeetCode初级算法之数学

    Fizz Buzz class Solution { public List<String> fizzBuzz(int n) { List<String> list=new L ...

  7. 算法练习LeetCode初级算法之设计问题

    打乱数组 不断的让第一个与后面随机选择的数交换 class Solution { private int[] nums; private int[] initnums; public Solution ...

  8. 算法练习LeetCode初级算法之排序和搜索

    合并两个有序数组 class Solution { public void merge(int[] nums1, int m, int[] nums2, int n) { System.arrayco ...

  9. 算法练习LeetCode初级算法之树

    二叉树的前序遍历 我的解法:利用递归,自底向下逐步添加到list,返回最终的前序遍历list class Solution { public List<Integer> preorderT ...

随机推荐

  1. 去中心化存储项目终极指南 | Filecoin, Storj 和 PPIO 项目异同

    Filecoin,Storj 以及 PPIO 这三个存储公链的设计思路是不一样的,没有优劣之分,写这篇文章也并不是为了争论各项目的好坏对错.去中心化存储是一个长期商业赛道,不同团队在同一个赛道上往不同 ...

  2. [UE4]模拟物理

    一.默认情况下Actor的Mobility(可移动性)是Static(静止),Simulate Physics(模拟物理):如果勾选Simulate Physics,则Mobility会自动变成Mov ...

  3. Mysql 数据库复制

    Mysql 数据库复制 数据库复制是一种同步手段,主库向一台或多台数据库同步数据. 这个功能我自己曾经用uts数据传输工具实现过! 现在学习了一下mysql数据库复制的其他方式 第一个就是最简单的使用 ...

  4. netmap配置

    1.配置流程 环境:centos 7.2.1511,内核版本3.10.0-327.el7.x86_64 [1]下载内核源码,https://buildlogs.cdn.centos.org/c7.15 ...

  5. mfc添加自定义事件

    1.在对话框的头文件里面添加声明函数: afx_msg void OnStnClickedPicStop(); 2.在对话框的源文件添加 BEGIN_MESSAGE_MAP(CPcEn3dTestDl ...

  6. sql 实现学生成绩并列排名算法

    SELECT uname, score , 排名=(SELECT COUNT(score) FROM FenShu WHERE Score > a.Score) + 1FROM FenShu a ...

  7. java——collection总结

    Collection 来源于Java.util包,是非常实用常用的数据结构!!!!!字面意思就是容器.具体的继承实现关系如下图,先整体有个印象,再依次介绍各个部分的方法,注意事项,以及应用场景.   ...

  8. Revit 命令添加下拉框

    在学习revit制作下拉框时,需要分为三个步骤: 1.创建一个面板(panel). RibbonPanel panel10 = application.CreateRibbonPanel(Global ...

  9. ORM项目中小知识点积累

    申明:一下内容均建立在零基础小白的角度上,大佬们求放过~ 1.如何通过类建立外键关联 2.模板语言固定搭配 3.浏览器报错处理 4.后台取值方式 5.外键管理修改相关操作 6.两种(给后台偷偷传递消息 ...

  10. Linux发行版:CentOS、Ubuntu、RedHat、Android、Tizen、MeeGo

    Linux,最早由Linus Benedict Torvalds在1991年开始编写.在这之前,Richard Stallman创建了Free Software Foundation(FSF)组织以及 ...