主頁 > 軟體設計 > LeetCode通關:堆疊和佇列六連,匹配問題有絕招

LeetCode通關:堆疊和佇列六連,匹配問題有絕招

2021-08-22 07:54:03 軟體設計

刷題路線參考:

https://github.com/chefyuan/algorithm-base

https://github.com/youngyangyang04/leetcode-master

大家好,我是靠寫博客督促自己刷題的老三,這一節我們對線堆疊和佇列,

堆疊和佇列基礎

在正式開刷之前,我們先了解一些堆疊和佇列的基礎知識,

堆疊的結構

堆疊是一種先進后出的順序表結構,

堆疊示意圖

堆疊的結構比較簡單,就不多了,

堆疊的實作

因為堆疊是一個線性表表,因此,線性表支持堆疊的操作,ArrayList 和 LinkedList 都可以作為堆疊來使用,

可以直接使用 Stack 類來進行創建一個堆疊,這個繼承的是過期,

Deque<TreeNode> stack = new LinkedList<TreeNode>();//型別為TreeNode
Stack<TreeNode> stack = new Stack<TreeNode>();

佇列結構

佇列是一種先進先出的資料結構

佇列結構

佇列實作

佇列也是表結構,比較常用的是由LinkedList實作,

  Queue<TreeNode> queue = new LinkedList<TreeNode>();

好了,兩種資料結構也比較簡單,開始我們的刷題之旅吧!

刷題現場

劍指 Offer 09. 用兩個堆疊實作佇列

? 題目:劍指 Offer 09. 用兩個堆疊實作佇列(https://leetcode-cn.com/problems/yong-liang-ge-zhan-shi-xian-dui-lie-lcof/)

? 難度:簡單

📕 描述:

用兩個堆疊實作一個佇列,佇列的宣告如下,請實作它的兩個函式 appendTail 和 deleteHead ,分別完成在佇列尾部插入整數和在佇列頭部洗掉整數的功能,(若佇列中沒有元素,deleteHead 操作回傳 -1 )

示例 1:

輸入:
["CQueue","appendTail","deleteHead","deleteHead"]
[[],[3],[],[]]
輸出:[null,null,3,-1]

示例 2:

輸入:
["CQueue","deleteHead","appendTail","appendTail","deleteHead","deleteHead"]
[[],[],[5],[2],[],[]]
輸出:[null,-1,null,null,5,2]

💡思路:

堆疊是先進后出,佇列是先進先出的資料結構,

那怎么用堆疊模擬佇列呢?

需要兩個堆疊,一個作為隊頭 headStack,一個作為隊尾 tailStack

  • tailStack 作為隊尾,模擬入隊操作,當有一個元素入隊時,則將其 push 到tailStack 堆疊頂,
  • headStack 作為隊頭,模擬出隊操作,當有一個元素出隊時,則將 headStack 堆疊頂的元素 pop,
  • 當 headStack 中沒有元素時,將 tailStack 中所有的元素都 push 進 headStack 中,

兩個堆疊模擬佇列

這樣一來,就用兩個堆疊模擬了佇列的出入順序,

我們來看一下代碼實作:

public class CQueue {

    //定義兩個堆疊
    Deque<Integer> headStack, tailStack;

    public CQueue() {
        headStack = new LinkedList<>();
        tailStack = new LinkedList<>();
    }

    //入隊
    public void appendTail(int value) {
        //入隊,往tailStack中壓入值
        tailStack.push(value);
    }

    //出隊
    public int deleteHead() {
        //如果隊頭為空
        if (headStack.isEmpty()) {
            //則將 tailStack (隊尾)的元素全部出堆疊,再壓入headStack
            while (!tailStack.isEmpty()) {
                headStack.push(tailStack.pop());
            }
        }
        if (headStack.isEmpty()) {
            return -1;
        }
        return headStack.pop();
    }
}

🚗 時間復雜度:入隊O(1,出隊O(n),

🏠 空間復雜度:引入了兩個堆疊,所以空間復雜度O(n),

還有一道題,LeetCode232. 用堆疊實作佇列 基本是一樣的,

LeetCode225. 用佇列實作堆疊

? 題目:225. 用佇列實作堆疊 (https://leetcode-cn.com/problems/implement-stack-using-queues/)

? 難度:簡單

📕 描述:

請你僅使用兩個佇列實作一個后入先出(LIFO)的堆疊,并支持普通堆疊的全部四種操作(pushtoppopempty),

實作 MyStack 類:

  • void push(int x) 將元素 x 壓入堆疊頂,
  • int pop() 移除并回傳堆疊頂元素,
  • int top() 回傳堆疊頂元素,
  • boolean empty() 如果堆疊是空的,回傳 true ;否則,回傳 false ,

注意:

  • 你只能使用佇列的基本操作 —— 也就是 push to backpeek/pop from frontsizeis empty 這些操作,
  • 你所使用的語言也許不支持佇列, 你可以使用 list (串列)或者 deque(雙端佇列)來模擬一個佇列 , 只要是標準的佇列操作即可,

示例:

輸入:
["MyStack", "push", "push", "top", "pop", "empty"]
[[], [1], [2], [], [], []]
輸出:
[null, null, null, 2, 2, false]

解釋:
MyStack myStack = new MyStack();
myStack.push(1);
myStack.push(2);
myStack.top(); // 回傳 2
myStack.pop(); // 回傳 2
myStack.empty(); // 回傳 False

💡 思路:

這道題,實不相瞞,乍一看,我有點想偷懶,因為如果用一個雙向佇列的話:

雙向對列

是不是啪一下就實作了,但是題目里面也說了,標準佇列操作,所以我們還是用單向佇列,

那我們怎么實作呢?

很簡單,入堆疊的時候,我們利用佇列先進先出的特點,每次佇列模擬入堆疊時,我們先將佇列之前入隊的元素都出隊,僅保留最后一個進隊的元素,

然后再重新入隊,這樣就實作了顛倒佇列中的元素,這樣就和堆疊中的次序是一樣的了,

佇列實作堆疊

代碼實作如下:

public class MyStack {
    //單向佇列
    Queue<Integer> queue;

    /**
     * Initialize your data structure here.
     */
    public MyStack() {
        queue = new LinkedList<>();
    }

    /**
     * Push element x onto stack.
     */
    public void push(int x) {
        //入隊元素
        queue.offer(x);
        //將之前的元素,出隊,重新入隊
        for (int i = 0; i < queue.size() - 1; i++) {
            queue.offer(queue.poll());
        }
    }

    /**
     * Removes the element on top of the stack and returns that element.
     */
    public int pop() {
        return queue.poll();
    }

    /**
     * Get the top element.
     */
    public int top() {
        return queue.peek();
    }

    /**
     * Returns whether the stack is empty.
     */
    public boolean empty() {
        return queue.isEmpty();
    }
}

🚗 時間復雜度:入堆疊O(n),出堆疊O(1),

🏠 空間復雜度:引入了佇列,空間復雜度O(n),

LeetCode20. 有效的括號

? 題目:20. 有效的括號 (https://leetcode-cn.com/problems/valid-parentheses/)

? 難度:簡單

📕 描述:

給定一個只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字串 s ,判斷字串是否有效,

有效字串需滿足:

  • 左括號必須用相同型別的右括號閉合,
  • 左括號必須以正確的順序閉合,

示例 1:

輸入:s = "()"
輸出:true

示例 2:

輸入:s = "()[]{}"
輸出:true

示例 3:

輸入:s = "(]"
輸出:false

示例 4:

輸入:s = "([)]"
輸出:false

示例 5:

輸入:s = "{[]}"
輸出:true

提示:

  • 1 <= s.length <= 104
  • s 僅由括號 '()[]{}' 組成

💡 思路:

這是一道經典的堆疊的應用的題目,

思路是什么呢?

碰到左括號把元素入堆疊,碰到右括號就和堆疊頂元素比較,如果相同就把堆疊頂元素出堆疊,不匹配,就直接回傳false,

有效括號堆疊匹配

代碼如下:注意處理堆疊為空的情況

    public boolean isValid(String s) {
        Deque<Character> stack = new LinkedList<>();
        //遍歷字串
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            //遇到左括號,入堆疊
            if (c == '(' || c == '[' || c == '{') {
                stack.push(c);
            }
            //右括號匹配
            if (c == ')') {
                if (stack.isEmpty() || stack.pop() != '(') {
                    return false;
                }
            }
            if (c == ']') {
                if (stack.isEmpty() || stack.pop() != '[') {
                    return false;
                }
            }
            if (c == '}') {
                if (stack.isEmpty() || stack.pop() != '{') {
                    return false;
                }
            }
        }
        return stack.isEmpty();
    }

🚗 時間復雜度:O(n),

🏠 空間復雜度:O(n),

LeetCode1047. 洗掉字串中的所有相鄰重復項

給出由小寫字母組成的字串 S,重復項洗掉操作會選擇兩個相鄰且相同的字母,并洗掉它們,

在 S 上反復執行重復項洗掉操作,直到無法繼續洗掉,

在完成所有重復項洗掉操作后回傳最終的字串,答案保證唯一,

示例:

輸入:"abbaca"
輸出:"ca"
解釋:
例如,在 "abbaca" 中,我們可以洗掉 "bb" 由于兩字母相鄰且相同,這是此時唯一可以執行洗掉操作的重復項,之后我們得到字串 "aaca",其中又只有 "aa" 可以執行重復項洗掉操作,所以最后的字串為 "ca",

💡 思路:

這道題是不是和上道題差不多,

遍歷字符,如果字符和堆疊頂元素匹配,就把堆疊頂元素出堆疊,

如果不匹配,就把元素入堆疊,

這樣一來,堆疊里最后剩下的都是相鄰不相同的元素,

洗掉字串相鄰重復項

代碼如下:最后出堆疊的元素需要倒轉

    public String removeDuplicates(String s) {
        Deque<Character> stack = new LinkedList<>();
        //遍歷字串
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            if (stack.isEmpty() || stack.peek() != c) {
                //入堆疊
                stack.push(c);
            } else {
                //堆疊頂元素出堆疊
                stack.pop();
            }
        }
        //拼接堆疊中字符
        StringBuilder str = new StringBuilder();
        while (!stack.isEmpty()) {
            str.append(stack.pop());
        }
        return str.reverse().toString();
    }

🚗 時間復雜度:O(n),

🏠 空間復雜度:O(n),

LeetCode150. 逆波蘭運算式求值

? 題目:150. 逆波蘭運算式求值 (https://leetcode-cn.com/problems/evaluate-reverse-polish-notation/)

? 難度:中等

📕 描述:

根據 逆波蘭表示法,求運算式的值,

有效的算符包括 +-*/ ,每個運算物件可以是整數,也可以是另一個逆波蘭運算式,

說明:

  • 整數除法只保留整數部分,

  • 給定逆波蘭運算式總是有效的,換句話說,運算式總會得出有效數值且不存在除數為 0 的情況,

示例 1:

輸入:tokens = ["2","1","+","3","*"]
輸出:9
解釋:該算式轉化為常見的中綴算術運算式為:((2 + 1) * 3) = 9

示例 2:

輸入:tokens = ["4","13","5","/","+"]
輸出:6
解釋:該算式轉化為常見的中綴算術運算式為:(4 + (13 / 5)) = 6

示例 3:

輸入:tokens = ["10","6","9","3","+","-11","*","/","*","17","+","5","+"]
輸出:22
解釋:
該算式轉化為常見的中綴算術運算式為:
  ((10 * (6 / ((9 + 3) * -11))) + 17) + 5
= ((10 * (6 / (12 * -11))) + 17) + 5
= ((10 * (6 / -132)) + 17) + 5
= ((10 * 0) + 17) + 5
= (0 + 17) + 5
= 17 + 5
= 22

逆波蘭運算式:

逆波蘭運算式是一種后綴運算式,所謂后綴就是指算符寫在后面,

  • 平常使用的算式則是一種中綴運算式,如 ( 1 + 2 ) * ( 3 + 4 ) ,
  • 該算式的逆波蘭運算式寫法為 ( ( 1 2 + ) ( 3 4 + ) * ) ,

逆波蘭運算式主要有以下兩個優點:

  • 去掉括號后運算式無歧義,上式即便寫成 1 2 + 3 4 + * 也可以依據次序計算出正確結果,
  • 適合用堆疊操作運算:遇到數字則入堆疊;遇到算符則取出堆疊頂兩個數字進行計算,并將結果壓入堆疊中,

💡 思路:

看到沒,這道題的提示里面就給出了思路:

適合用堆疊操作運算:遇到數字則入堆疊;遇到算符則取出堆疊頂兩個數字進行計算,并將結果壓入堆疊中,

逆波蘭運算式求值

代碼實作如下:

    public int evalRPN(String[] tokens) {
        Deque<Integer> stack = new LinkedList<>();
        for (int i = 0; i < tokens.length; i++) {
            String s = tokens[i];
            if (isNumber(s)) {
                stack.push(Integer.parseInt(s));
            } else {
                int num1 = stack.pop();
                int num2 = stack.pop();
                if (s.equals("+")) {
                    stack.push(num1 + num2);
                } else if (s.equals("-")) {
                    stack.push(num2 - num1);
                } else if (s.equals("*")) {
                    stack.push(num1 * num2);
                } else if (s.equals("/")) {
                    stack.push(num2 / num1);
                }
            }

        }
        return stack.pop();
    }

    boolean isNumber(String token) {
        return !("+".equals(token) || "-".equals(token) || "*".equals(token) || "/".equals(token));
    }

🚗 時間復雜度:O(n),

🏠 空間復雜度:O(n),

LeetCode402. 移掉 K 位數字

? 題目:150. 逆波蘭運算式求值 (https://leetcode-cn.com/problems/evaluate-reverse-polish-notation/)

? 難度:中等

📕 描述:

給你一個以字串表示的非負整數 num 和一個整數 k ,移除這個數中的 k 位數字,使得剩下的數字最小,請你以字串形式回傳這個最小的數字,

示例 1 :

輸入:num = "1432219", k = 3
輸出:"1219"
解釋:移除掉三個數字 4, 3,2 形成一個新的最小的數字 1219

示例 2 :

輸入:num = "10200", k = 1
輸出:"200"
解釋:移掉首位的 1 剩下的數字為 200. 注意輸出不能有任何前導零,

示例 3 :

輸入:num = "10", k = 2
輸出:"0"
解釋:從原數字移除所有的數字,剩余為空就是 0 ,

💡 思路:

  • 遍歷字串 s,若當前堆疊不為空并且堆疊頂元素的值大于當前遍歷的元素值并且移除元素的個數沒有達到要求 k,則堆疊頂元素出堆疊,count 值加 1,

  • 若當前遍歷的元素比堆疊頂元素的值要大,則直接將該元素壓堆疊,

  • 若當前遍歷的元素值為 " 0 " 并且堆疊為空,則直接跳過這次回圈(要保證堆疊底的元素不能為 " 0 ",因為題目要求 num 不會包含任何前導零,就是不能用 " 0 " 來開頭),

  • 若遍歷完整個字串而 count < k(移除的元素個數沒有達到要求,示例:num = “123456”, k = 3),此時直接將堆疊中的前三個元素依次出堆疊,即 " 654 " 出堆疊剩下的 " 321 " 翻轉一下,即為最小值,

  • 若當前堆疊為空(去掉一個最大的元素后,其余元素均為 " 0 "),則直接回傳 " 0 " 即可,

代碼如下:

    public String removeKdigits(String num, int k) {
        if (k == num.length()) return "0";
        //堆疊
        Deque<Character> stack = new LinkedList<>();
        int count = 0;
        for (int i = 0; i < num.length(); i++) {
            while (!stack.isEmpty() && stack.peek() > num.charAt(i) && count < k) {
                stack.pop();
                count++;
            }
            //堆疊為空,且當前位為0時,我們不需要將其入堆疊
            if (num.charAt(i) == '0' && stack.isEmpty()) continue;
            stack.push(num.charAt(i));
        }
        while (!stack.isEmpty() && count < k) {
            stack.pop();
            count++;
        }
        //這個是最后堆疊為空時,洗掉一位,比如我們的10,洗掉一位為0,
        //按上面邏輯我們會回傳"",所以我們讓其回傳"0"
        if (stack.isEmpty()) return "0";
        StringBuffer sb = new StringBuffer();
        while (!stack.isEmpty()) {
            sb.append(stack.pop());
        }
        return sb.reverse().toString();
    }

總結

大家熟悉😂的順口溜總結:

總結


簡單的事情重復做,重復的事情認證做,認證的事情有創造性地做,——

我是三分惡,一個能文能武的全堆疊開發,

點贊關注不迷路,咱們下期見,



參考:

[1]. https://github.com/youngyangyang04/leetcode-master

[2]. https://github.com/chefyuan/algorithm-base

[3]. https://leetcode-cn.com/problems/remove-k-digits/solution/yi-diao-kwei-shu-zi-zhan-by-booooo_-01nh/

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/295452.html

標籤:其他

上一篇:nginx負載均衡session共享

下一篇:C++之模板初階:甩鍋編譯器

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more