滑动窗口最大数

时间:2020-05-21
本文章向大家介绍滑动窗口最大数,主要包括滑动窗口最大数使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}; 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5],1}, {2,3,4,2,6,[2,5,1]}。

class Solution:
    def maxInWindows(self, num, size):
        # write code here
        if size<=0:
            return []
        res=[]
        for i in range(len(num)-size+1):
            res.append(max(num[i:i+size]))
        return res

给定一棵二叉搜索树,请找出其中的第k小的结点。例如, (5,3,7,2,4,6,8)    中,按结点数值大小顺序第三小结点的值为4。

思路:搜素二叉树的中序遍历是排好顺序的序列,所以可以直接先进行中序遍历,在中序遍历后直接输出下表为k-1的元素就是第k小的数据

class Solution:
    def KthNode(self,pRoot,k):
        self.res=[]
        self.midsort(pRoot)
        return self.res[k-1] if 0<k<=len(self.res) else None
    def midsort(self,root):
        if not root:
            return
        self.midsort(root.left)
        self.res.append(root)
        self.midsort(root.right)

原文地址:https://www.cnblogs.com/zxixiu/p/12928689.html