4.17周五

做题

今天做了一个BFS、贪心的题,可以好好研究一下:力扣55跳跃游戏。

给定一个非负整数数组,你最初位于数组的第一个位置。
数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个位置。

一开始就用了最普通的暴力BFS,对每个位置,可能的到达的位置都进行入队,然后依次遍历下去,如果nums[i]==0就直接出队,不进行处理。但是这个方法很明显会超时,所以在评论区看到了一个进行了一些优化的BFS,他进行了以下优化:

  1. 对于出队入队的处理,在while循环内用for循环对队列中已存在的所有元素进行出队和入队的操作。
  2. 用visited数组处理已经遍历过的位置,避免用contains操作来造成O(n)复杂度的搜索。
class Solution {
    public boolean canJump(int[] nums) {
        Queue<Integer> q = new LinkedList<>();
        boolean[] visited = new boolean[nums.length];
        q.offer(0);
        while(!q.isEmpty()) {
            for(int size=q.size();size>0;size--) {
                // idx is current position
                int idx = q.remove();
                // if this condition is true, we can find an answer
                if(idx >= nums.length - 1) return true;
                // i is the next rightmost position we can reach
                for(int i=idx + 1;i < nums.length &&
                    i<=idx + nums[idx];i++) {
                    if(visited[i]) continue;
                    visited[i] = true;
                    q.offer(i);
                }
            }
        }
        return false;
    }
}

然后是官方题解的贪心算法,这里主要的思想就是维护一个最远能到达的位置,当最远能到达的位置超过数组长度时就返回true,主要是要吸纳维护最远位置这个思想,在以后的题目中也多一个思路。

public class Solution {
    public boolean canJump(int[] nums) {
        int n = nums.length;
        int rightmost = 0;
        for (int i = 0; i < n; ++i) {
            if (i <= rightmost) {
                rightmost = Math.max(rightmost, i + nums[i]);
                if (rightmost >= n - 1) {
                    return true;
                }
            }
        }
        return false;
    }
}
用PYTHON编写自1971年7月开始,道琼斯工业股票平均价格指数每周收盘价如表所示(行数据)。 890.19 901.8 888.51 887.78 858.43 850.61 856.02 880.91 908.15 912.75 911 908.22 889.31 893.98 893.91 874.85 852.37 839 840.39 812.94 810.67 816.55 859.59 856.75 873.8 881.17 890.2 910.37 906.68 907.44 906.38 906.68 917.59 917.52 22.79 942.43 939.87 942.88 942.28 940.7 962.6 967.72 963.8 954.17 941.23 941.83 961.54 971.25 961.39 934.45 945.06 944.69 929.03 938.06 922.26 920.45 926.7 951.76 964.18 965.83 959.36 970.05 961.24 947.23 943.03 953.27 945.36 930.46 942.81 946.42 984.12 995.26 1005.57 1025.21 1023.43 1033.19 1027.24 1004.21 1020.02 1047.49 1039.36 1026.19 1003.54 980.81 979.46 979.23 959.89 961.32 972.23 963.05 922.71 951.01 931.07 959.36 963.2 922.19 953.87 927.89 895.17 930.84 893.96 920 888.55 879.82 891.71 870.11 885.99 910.9 936.71 908.87 852.38 871.84 863.49 887.57 898.63 886.36 927.9 947.1 971.25 978.63 963.73 987.06 935.28 908.42 891.33 854 822.25 838.05 815.65 818.73 848.02 880.23 841.48 855.47 859.39 843.94 820.4 820.32 855.99 851.92 878.05 887.83 878.13 846.68 847.54 844.81 859.9 834.64 845.9 850.44 818.84 816.65 802.17 853.72 843.09 815.39 802.41 791.77 787.23 787.94 784.57 752.58(1)检验该序列的平稳性。 (2)对该序列拟合适当的ARIMA模型提取水平信息。 (3)考察该序列是否具有条件异方差属性。如果有条件异方差属性,则拟合适当的条件异方差模型。 (4)使用拟合模型预测该序列未来4周的收盘价及收盘价的95%的置信区间。
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值