成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

一維滑動(dòng)窗口(SlidingWindow)

hlcfan / 2952人閱讀

摘要:滑動(dòng)窗口問(wèn)題經(jīng)常使用快慢指針的區(qū)域?yàn)榛瑒?dòng)窗口已經(jīng)探索過(guò)的區(qū)域的區(qū)域?yàn)榛瑒?dòng)窗口正在探索的區(qū)域?yàn)榇剿鞯膮^(qū)域的問(wèn)題主要分為和當(dāng)快指針增加的時(shí)候慢指針必須增加快指針增加,慢指針不一定變化使用滑動(dòng)窗口可以線性時(shí)間解決問(wèn)題而且可以減少空間消耗要求

滑動(dòng)窗口(Sliding Window)問(wèn)題經(jīng)常使用快慢指針(slow, fast pointer)
[0, slow)?的區(qū)域?yàn)榛瑒?dòng)窗口已經(jīng)探索過(guò)的區(qū)域
[slow, fast]的區(qū)域?yàn)榛瑒?dòng)窗口正在探索的區(qū)域
(fast, end of array)為待探索的區(qū)域

Sliding Window的問(wèn)題主要分為:
fixed size sliding windowdynamic size sliding window

fixed size sliding window: 當(dāng)快指針增加的時(shí)候慢指針必須增加
non-fixed size sliding window: 快指針增加,慢指針不一定變化

使用滑動(dòng)窗口可以線性時(shí)間解決問(wèn)題而且可以減少空間消耗

Fixed Length Sliding Window:
1.Strstr:
Return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.
Input: haystack = "hello", needle = "ll"
Output: 2
要求找到短字符串在的起始位置在長(zhǎng)字符串中的位置
所以只需要保持一個(gè)fixed sliding window的長(zhǎng)度為短字符串的長(zhǎng)度然后掃長(zhǎng)字符串來(lái)尋找起始位置

   class Solution{
       public int strStr(String long, String short) {
           //sanity check
            if(long == null || short == null) return -1;
            int i = 0;
            int j = needle.length();
            while(i <= haystack.length() - needle.length() && j <= haystack.length()) {
                if(haystack.substring(i, j).equals(needle)) {
                    return i;
                }
                i++;
                j++;
            }
            return -1;
         }
    }

2.Repeated DNA Sequennce
All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: "ACGAATTCCG". When studying DNA, it is sometimes useful to identify repeated sequences within the DNA.
Write a function to find all the 10-letter-long sequences (substrings) that occur more than once in a DNA molecule.
Given s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT",
Return:
["AAAAACCCCC", "CCCCCAAAAA"]
這道題給一個(gè)堿基序列,要求我們返回在given的堿基序列中重復(fù)的堿基序列
所以這道題我們可以用一個(gè)定長(zhǎng)的滑動(dòng)窗口,每次去match在given的堿基序列中任意的position從而返回所用出現(xiàn)過(guò)的重復(fù)的堿基序列,可以用一個(gè)HashSet的數(shù)據(jù)結(jié)構(gòu)來(lái)判斷是否已經(jīng)檢查過(guò)已經(jīng)出現(xiàn)的序列

class Solution{
    public List repeatedDNASequence(String s) {
        HashSet window = new HashSet();
        HashSet repeated = new HashSet();
        
        for(int i = 0; i < s.length() - 9; i++) {
            if(!window.add(s.substring(i, i + 10))) {
                repeated.add(s.substring(i, i + 10));
            }
        }
        return new ArrayList(repeated);
    }
}

Non-fixed Size Sliding-Window
3.find all anagrams of shortString in longString
Given a string s and a non-empty string p, find all the start indices of p"s anagrams in s.Strings consists of lowercase English letters only and the length of both strings s and p will not be larger than 20,100.The order of output does not matter.
Example 1:
Input:s: "cbaebabacd" p: "abc"
Output:[0, 6]
Explanation:
The substring with start index = 0 is "cba", which is an anagram of "abc".
The substring with start index = 6 is "bac", which is an anagram of "abc".
Example 2:
Input: s: "abab" p: "ab"
Output: [0, 1, 2]
Explanation:
The substring with start index = 0 is "ab", which is an anagram of "ab".
The substring with start index = 1 is "ba", which is an anagram of "ab".
The substring with start index = 2 is "ab", which is an anagram of "ab".
這道題是尋找input長(zhǎng)字符串中所有出現(xiàn)子串的起始字母在長(zhǎng)字符串中的位置
因?yàn)槲覀冃枰业介L(zhǎng)字符串中所有match子串的字符串并且返回需要match的字串中第一個(gè)字母在長(zhǎng)字符串中的位置,所以需要用一個(gè)動(dòng)態(tài)的滑動(dòng)窗口慢指針在match的子字符串的第一個(gè)字母在長(zhǎng)字符串中的位置,快指針在最后一個(gè)match的字母在長(zhǎng)字符串中的位置, 然后需要一個(gè)hashmap來(lái)記錄每個(gè)字母出現(xiàn)的頻率,利用length來(lái)teminate

class Solution{
    public List findAnagrams(String s, String p) {
        //sanity check
        List res = new ArrayList();
        //count the frequency of each appeared character
        Map map = new HashMap();
        for(char c : p.toCharArray()) {
            map.put(c, map.getOrDefault(0, c) + 1);
        }
        int fast = 0;
        int slow = 0;
        int count = map.size();//記錄所有出現(xiàn)過(guò)字符的頻率
        //update fast pointer
        while(fast < s.length()) {
            char c = s.charAt(fast);
            if(map.containsKey(s.charAt(fast)) {
                map.put(c, map.get(fast) - 1);
                if(map.get(c) == 0) count--;
            }
            fast++;
            //update slow pointer
            while(count == 0) {
                char temp = s.charAt(slow);
                if(map.containsKey(temp)) {
                    map.put(temp, map.get(temp) + 1));
                    if(map.get(temp) > 0) count++;
                }
                //store res;
                if(fast - slow == p.length()) {
                    res.add(slow);
                }
                slow++;
            }
       }
       return res;
    }
}

4.Maximum Value of size K subarray
Given an array nums, there is a sliding window of size k which is moving from the very left of the array to the very right. You can only see the k numbers in the window. Each time the sliding window moves right by one position.
這題要求找到given數(shù)組中任意定長(zhǎng)的滑動(dòng)窗口中數(shù)的最大值,因此需要考慮一個(gè)數(shù)據(jù)結(jié)構(gòu)可以在移動(dòng)的滑動(dòng)窗口中找到最大值,因此有幾種想法:
1.在定長(zhǎng)的滑動(dòng)窗口里維持一個(gè)最大堆,因此我們可以用constant時(shí)間去找到最大值,但是考慮到每次heapify的時(shí)間需要O(logn),所以找到k個(gè)最大值需要花費(fèi)O(klogn)的時(shí)間
2.還是同樣在定長(zhǎng)的滑動(dòng)窗口里維持一個(gè)treeset,但是考慮到每次在treeset中添加或者刪除元素需要花費(fèi)O(logn)的時(shí)間,所以是否存在一個(gè)數(shù)據(jù)結(jié)構(gòu)可以在線性時(shí)間內(nèi)得到定長(zhǎng)滑動(dòng)窗口里的最大值?
3.因而,想到了雙端隊(duì)列(Deque),可以維持一個(gè)遞增的雙端隊(duì)列
EX:[|1, 4|, 5, 3, 9], k = 3
我們先將k-1個(gè)元素放入隊(duì)列:|2|
然后從第k個(gè)元素開(kāi)始,一次加入新元素并刪除舊元素,并且保持滑動(dòng)窗口的size不變
[|1, 4, 5|, 3, 9], Deque: 5, Output: [5];
[1, |4, 5, 3|, 9], Deque: 5, 5, Output: [5, 5];
[1, 4, |5, 3, 9|], Deque: 8, Output: [5, 5, 8];
因?yàn)閷?duì)于每個(gè)數(shù)組中的元素只掃描一次,所以總體時(shí)間在deque操作中也近似于線性,所以總運(yùn)行時(shí)間:O(n)(amortized), 空間復(fù)雜度:O(1)

class slidingWindowMax{
    public void inQueue(Deque deque, int k) {
        while(!deque.isEmpty() && deque.peekLast() < k) {
            deque.pollLast();
        }
        deque.offerLast(num);
    }
    public void outQueue(Deque deque, int k) {
           if(deque.peekFirst() == k) {
               deque.pollFirst();
           }
    }
    public int[] maxSlidingWindow(int[] nums, int k) {
        List ans = new ArrayList();
        Deque deque = new ArrayDeque();
        
        if(nums == null || nums.length == 0) {
            return new int[]{};
        }
        
        for(int i = 0; i < k - 1; i++) {
            inQueue(deque, nums[i]);
        }
        
        for(int i = k - 1; i < nums.length; i++) {
            inQueue(deque, nums[i]);
            res.add(deque.peekFirst());
            outQueue(deque, nums[i - k + 1]);//delete old element
         }
         int[] res = new int[ans.size()];
         int h = 0;
         for(int num : res) {
             res[h++] = num;
         }
         return res;
    }
}
           
        
         
         
      
  
    
    
    







             
              
       
      
   
      
        




文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/68315.html

相關(guān)文章

  • 數(shù)據(jù)結(jié)構(gòu)與算法隨筆之優(yōu)先隊(duì)列-求滑動(dòng)窗口最大值(三)

    摘要:你只可以看到在滑動(dòng)窗口內(nèi)的數(shù)字?;瑒?dòng)窗口每次只向右移動(dòng)一位。返回滑動(dòng)窗口最大值。 這篇文章我們來(lái)看一道題目求滑動(dòng)窗口最大值問(wèn)題(在leetcode上的地址:滑動(dòng)窗口最大值) 題目描述 給定一個(gè)長(zhǎng)度為N的數(shù)組 nums,有一個(gè)大小為 k 的滑動(dòng)窗口從數(shù)組的最左側(cè)移動(dòng)到數(shù)組的最右側(cè)。你只可以看到在滑動(dòng)窗口 k 內(nèi)的數(shù)字?;瑒?dòng)窗口每次只向右移動(dòng)一位。返回滑動(dòng)窗口最大值。 示例: 輸入: nu...

    Joyven 評(píng)論0 收藏0
  • Tensorflow Python API 翻譯(nn)

    摘要:表示元素是否放電的概率。更加具體的表示細(xì)節(jié)為注意,必須有。數(shù)據(jù)維度是四維。在大部分處理過(guò)程中,卷積核的水平移動(dòng)步數(shù)和垂直移動(dòng)步數(shù)是相同的,即。 作者:chen_h微信號(hào) & QQ:862251340微信公眾號(hào):coderpai簡(jiǎn)書(shū)地址:https://www.jianshu.com/p/e3a... 計(jì)劃現(xiàn)將 tensorflow 中的 Python API 做一個(gè)學(xué)習(xí),這樣方便以后...

    lx1036 評(píng)論0 收藏0
  • 如何使用數(shù)組實(shí)現(xiàn)滑動(dòng)窗口

    摘要:理解數(shù)組實(shí)現(xiàn)的滑動(dòng)窗口,看下邊這個(gè)圖就可以了。第秒,開(kāi)始計(jì)數(shù),此時(shí)數(shù)組內(nèi)開(kāi)始存入計(jì)數(shù)周期,保存在數(shù)組第個(gè)位置,表示這是當(dāng)前滑動(dòng)窗口內(nèi)的第個(gè)計(jì)數(shù)周期。在FireflySoft.RateLimit之前的版本中,進(jìn)程內(nèi)滑動(dòng)窗口的實(shí)現(xiàn)是基于MemoryCache做的,雖然能夠正確的實(shí)現(xiàn)滑動(dòng)窗口的算法邏輯,但是性能比較差,其吞吐量只有其它算法的1/4。性能為何如此之差呢?滑動(dòng)窗口的原理我們先來(lái)看下滑動(dòng)...

    不知名網(wǎng)友 評(píng)論0 收藏0
  • 接口限流的常用算法匯總

    摘要:接口限流的常用算法計(jì)數(shù)器法計(jì)數(shù)器法是限流算法里最簡(jiǎn)單也是最容易實(shí)現(xiàn)的一種算法。由此可見(jiàn),當(dāng)滑動(dòng)窗口的格子劃分的越多,那么滑動(dòng)窗口的滾動(dòng)就越平滑,限流的統(tǒng)計(jì)就會(huì)越精確。漏桶算法漏桶算法,又稱。 接口限流 什么是接口限流 那么什么是限流呢?顧名思義,限流就是限制流量,包括并發(fā)的流量和一定時(shí)間內(nèi)的總流量,就像你寬帶包了1個(gè)G的流量,用完了就沒(méi)了,所以控制你的使用頻率和單次使用的總消耗。通過(guò)限...

    gyl_coder 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

hlcfan

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<