主頁 > 軟體設計 > C++ 吃透動態規劃演算法

C++ 吃透動態規劃演算法

2021-08-17 08:15:44 軟體設計

文章目錄

  • 1. 介紹
  • 2. 子序列問題
    • 1143.最長公共子序列
    • 300.最長遞增子序列
    • 2.1 最長遞增子序列應用
      • 354.俄羅斯套娃
      • [17.08 馬戲團人塔](https://leetcode-cn.com/problems/circus-tower-lcci/)
  • 3. 路徑問題
    • [64. 最短路徑和](https://leetcode-cn.com/problems/minimum-path-sum/)
    • [221. 最大正方形](https://leetcode-cn.com/problems/maximal-square/)
  • 4. 背包問題
    • 01背包問題
    • 01背包問題的應用 是否可以一個陣列分成和相等的兩部分
    • 4.2 完全背包問題
  • 5. 分割問題

1. 介紹

  • 動態規劃 (Dynamic Programming, DP)
  • 保存子問題, 避免重復計算
  • 關鍵是: 找到轉移方程, 確定邊界條件, 明確dp陣列含義
  • 比如我們熟悉的斐波那契數列, 其實dp跟遞回是一樣的, 只是因為遞回占用時間和空間較大, 所以盡可能使用dp解題, 事半功倍.
int feiB(int n){
	if(n<=1) return n;
	vector<int>dp(n+1, 0); //多出來一個, 因為feiB(3) = 2
	dp[0]=0, dp[1]=1;  // 邊界條件
	for(int i=2; i<=n; i++){ 
		dp[i] = dp[i-1]+dp[i-2]; // 轉移方程
	}
	cout<<n<<"的結果是"<<dp[n]<<endl;
	return dp[n];
}

2. 子序列問題

解題思路:

  1. 思考問題能不能轉化成樹的形式
  2. 思考樹是不是自底向上求取結果
  3. 根據這個樹, 確定自底向上的關系式, 比如上層節點A = 下層節點(A1+A2)
  4. 具體操作見下面的示例圖解

這部分問題, 筆試面試的時候出的特別多, 因為這部分問題如果有思路, 很快就能確定解決方案, 并且代碼量不多, 只需要理解動態規劃就會很好寫, 具體的題目見下面, 對于前兩個題兩個題太重要了, 一定要牢牢掌握住, 為后面的筆試面試奠基牢固的基礎, 因為第三個題往后都是這兩個題的延伸延伸延伸.

1143.最長公共子序列

給定兩個字串 text1text2,回傳這兩個字串的最長 公共子序列 的長度,如果不存在 公共子序列 ,回傳 0

輸入:text1 = "abcde", text2 = "ace" 
輸出:3  
解釋:最長公共子序列是 "ace" ,它的長度為 3 ,
輸入:text1 = "abc", text2 = "abc"
輸出:3
解釋:最長公共子序列是 "abc" ,它的長度為 3 ,
輸入:text1 = "abc", text2 = "def"
輸出:0
解釋:兩個字串沒有公共子序列,回傳 0 ,

請添加圖片描述

int longestCommonSubsequence(string text1, string text2) {
	int m=text1.size();
	int n=text2.size();
	vector<vector<int>> dp(m+1, vector<int>(n+1, 0));
	//print_vv(dp);
	for(int i=1; i<=m; i++){
		for (int j = 1; j<=n; ++j) {
			if(text1[i-1]==text2[j-1]) dp[i][j]=dp[i-1][j-1]+1;
			else dp[i][j]=max(dp[i-1][j], dp[i][j-1]);
		}
	}
	//print_vv(dp);
	return dp[m+1][n+1];
}

string text1="abcde";
string text2="ace";
int a = longestCommonSubsequence(text1, text2);

300.最長遞增子序列

給你一個整數陣列 nums ,找到其中最長嚴格遞增子序列的長度,
子序列是由陣列派生而來的序列,洗掉(或不洗掉)陣列中的元素而不改變其余元素的順序,例如,[3,6,2,7] 是陣列 [0,3,1,6,2,2,7] 的子序列,

輸入:nums = [10,9,2,5,3,7,101,18]
輸出:4
解釋:最長遞增子序列是 [2,3,7,101],因此長度為 4 ,
輸入:nums = [0,1,0,3,2,3]
輸出:4

請添加圖片描述
由上圖可知, 比如第4個位置對應的最長遞增子序列, 其結果跟前三個位置都相關

class Solution {
public:
    // 可能是動態規劃, 從底層往上層走, 發現4跟123有關, 即4是123其中最大值加一如果4大于123
    int lengthOfLIS(vector<int>& nums) {
        if(nums.empty()) return 0;
        int n=nums.size();
        
        vector<int> dp(n, 1); // 只要陣列不空, 遞增子序列最差也是1
        for(int i=0; i<n; i++){
            for(int j=0; j<i; j++){
                if(nums[i] > nums[j]){
                    dp[i] = max(dp[i], dp[j]+1);
                }
            }
        }
        // print_v(dp);
        return *max_element(dp.begin(), dp.end());
    }
};

2.1 最長遞增子序列應用

354.俄羅斯套娃

17.08 馬戲團人塔

做完上面那倆題之后, 在做這個題, 如果這個題還不會做, 請重復做上面那倆題, 直到不看答案, 能夠解決這個題, 算成功

給你一個二維整數陣列 envelopes ,其中 envelopes[i] = [wi, hi] ,表示第 i 個信封的寬度和高度,當另一個信封的寬度和高度都比這個信封大的時候,這個信封就可以放進另一個信封里,如同俄羅斯套娃一樣,
請計算 最多能有多少個 信封能組成一組“俄羅斯套娃”信封(即可以把一個信封放到另一個信封里面),
注意:不允許旋轉信封,

輸入:envelopes = [[5,4],[6,4],[6,7],[2,3]]
輸出:3
解釋:最多信封的個數為 3, 組合為: [2,3] => [5,4] => [6,7],

輸入:envelopes = [[1,1],[1,1],[1,1]]
輸出:1

思考:
首先想一下, 如果說把這個二維變成一維, 是不是就是最長遞增子序列
只不過這個題增加了一個維度, 那我們思考一下, 能不能先對一側進行排序, 然后在另一側計算最長遞增子序列呢???
答案很顯然是可以的

輸入:envelopes = [[5,4],[6,4],[6,7],[2,3]]
先對list的第一列排序, [[2,3], [5,4], [6,4], [6,7]]
然后在對第一列相等的, 倒敘排序第二列 , [[2,3], [5,4], [6,7], [6,4]]
然后在看[3,4,7,4]的最長遞增子序列即可
思考: 第一個排序可以理解, 為何倒敘排列第二列???
參考 [[2,3], [5,4], [5,8], [6,7], [6,6], [6,3]]
這里如果[[5,4], [5,8]]是順序, 則[3,4,8,7] 最長子序列是3, 也就是吧[5,4] 包金來了, 
但是[[6,7], [6,6], [6,3]], [3,4,8,7,6,3], 就不會把[[6,6], [6,3]]包進來;

請添加圖片描述

class Solution {
public:
    struct myCompare{
        bool operator()(vector<int> &a, vector<int> &b){
            // 先對第一列進行排序, 如果第一列有相等的比如[2,1], [2,3] 在對第二列進行排列成[2,3],[2,1],
            return (a[0] < b[0]) || (a[0]==b[0] && a[1] > b[1]);
        }
    };

    int maxEnvelopes(vector<vector<int>> &nums){
        if(nums.empty()) return 0;
        int n=nums.size();
        sort(nums.begin(), nums.end(), myCompare()); // 按要求排序
        vector<int>dp (n, 1);
        for(int i=0; i<n; i++){
            for(int j=0; j<i; j++){
                if(nums[i][1] > nums[j][1]){
                    dp[i] = max(dp[i], dp[j]+1);
                }
            }
        }
        return *max_element(dp.begin(), dp.end());
        
    }
};

3. 路徑問題

64. 最短路徑和

給定一個包含非負整數的m x n網格grid ,請找出一條從左上角到右下角的路徑,使得路徑上的數字總和為最小,
說明:每次只能向下或者向右移動一步,

輸入:grid = [[1,3,1],[1,5,1],[4,2,1]]
輸出:7
解釋:因為路徑 1→3→1→1→1 的總和最小,
輸入:grid = [[1,2,3],[4,5,6]]
輸出:12

在這里插入圖片描述

思考:

  1. 最短路徑和有點像貪婪演算法的意思
  2. 從左上角開始, 找右/下最小值走, 但是顯然不對, 就如上圖所示
  3. 但是可以想一下, 當前值只跟左/上兩個有關系, 所以最終dp[i][j]就可表示為從(0,0)->(i,j)的對小花費
dp[i][j] = min(dp(i-1, j) , dp(i, j-1)) + nums[i][j];
邊界條件就是dp的第一列和第一行是nums的累加
class Solution {
public:
    int minPathSum(vector<vector<int>>& nums) {
        if(nums.empty() || nums[0].empty()) return 0;
        int m = nums.size(), n = nums[0].size();

        vector<vector<int>> dp(m, vector<int>(n));

        for(int i=0; i<m; i++){
            for(int j=0; j<n; j++){
                if(i==0 && j==0) dp[0][0] = nums[0][0];
                else if(i==0) dp[i][j] = dp[i][j-1]+nums[i][j];
                else if(j==0) dp[i][j] = dp[i-1][j]+nums[i][j];
                else dp[i][j] = min(dp[i-1][j], dp[i][j-1])+nums[i][j];
            }
        }
        return dp[m-1][n-1];
    }
};

221. 最大正方形

在一個由 ‘0’ 和 ‘1’ 組成的二維矩陣內,找到只包含 ‘1’ 的最大正方形,并回傳其面積,

輸入:matrix = [["1","0","1","0","0"],["1","0","1","1","1"],["1","1","1","1","1"],["1","0","0","1","0"]]
輸出:4

在這里插入圖片描述

  1. dp[i][j]表示從i,j到左上的正方形邊長
class Solution {
public:
    int min_3(int &a, int &b, int &c){
        return min(min(a, b),c);
    }

    /*
    1. dp[i][j] 表示從(i,j)到 左上方 最大的正方形的邊長
    2. dp[i][j] = min(左, 上, 左對角) + 1
    */
    int maximalSquare(vector<vector<char>>& nums) {
        if(nums.empty() || nums[0].empty()) return 0;
        int m=nums.size(), n=nums[0].size();

        int ans=0;
        vector<vector<int>>dp(m, vector<int>(n,0));
        for(int i=0; i<m; i++){
            for(int j=0; j<n; j++){
                if(i==0 || j==0){
                    dp[i][j] = nums[i][j] - '0';
                }
                else if(nums[i][j] == '1'){
                    dp[i][j] = min_3(dp[i-1][j], dp[i][j-1], dp[i-1][j-1]) + 1;
                }
                ans = max(ans, dp[i][j]);
            }
        }
        return ans*ans;
    }
};

4. 背包問題

  • 組合優化的 NP 完全問題

  • 有 N 個物品和容量為 W 的背包,每個物品都有自己的體積 w 和價值 v,求拿哪些物品可以使得背包所裝下物品的總價值最大,限定每種物品只能選擇 0 個或 1 個,則問題稱為 0-1 背包問題;如果不限定每種物品的數量,則問題稱為無界背包問題或完全背包問題,

  • 對于背包問題動態方程,

  • 設dp[i,j]表示第i物品容量為j的位置背包的價值最多
    因此可以考慮這樣求解
    i物品放入背包, 此時背包減去i物品重量后,剩余空間是j-w[i], 所以找到上一個物品的j-w[i]

01背包問題

在這里插入圖片描述

  • 這里需要注意的是: 邊界條件
  • 跳轉關系見圖示
    在這里插入圖片描述
/*
1. dp含義: dp[i][j] 表示任取0-i的物品放到容量為j的背包里面的最大值
2. 遞推公式: dp[i][j]取決于當前物品
             i不放 dp[i][j]=dp[i-1][j] 就跟上一個物品放不放一致
             i放dp[i][j]=dp[i-1][j-weight[i]] + value[i] 空間減掉當前物品空間, 價值加上當前拿物品的價值,
3. 初始化: 第一行和第一列
4. 回圈順序: 
*/
int bakage_01(vector<int> weight, vector<int> value, int maxW){
    vector<vector<int>> dp(weight.size(), vector<int>(maxW+1, 0));
    for(int i=0; i<weight.size(); i++){ //物品
        for(int j=1; j<=maxW; j++){ // 背包容積
            if(i == 0 && weight[0] <= j) { // 第一行, 第一個物品如果重量大于背包容量, 則為value0
                dp[0][j] = value[0];
            }else if(j < weight[i]){ // 背包容積小
                dp[i][j] = dp[i-1][j]; //只跟上一個物品相關
            }else{
                dp[i][j] = max(dp[i-1][j], dp[i-1][j-weight[i]] + value[i]);
            }
        }
    }
    print_vv(dp);
    return dp[weight.size()-1][maxW];
}
  • 空間壓縮
    因為上面dp[i]行值只與i-1相關, 所以只需要定義一維空間, 一行一行進行填寫, 最后完成dp[j]即為所求
// 空間壓縮
int knapsack_optimize(vector<int> weights, vector<int> values, int N, int W) {
	vector<int>dp(W+1, 0);
	int w,v;
	for(int i=1; i<=N; i++){
		w=weights[i-1], v=values[i-1];
		for(int j = W; j>=w; j--){ // 這里大于w是為了去除沒用的, 也可以為j>0
			dp[j] = max(dp[j], dp[j-w]+v);
		}
		print_v(dp);
	}
	return dp[W];
}

01背包問題的應用 是否可以一個陣列分成和相等的兩部分

416. 是否可以一個陣列分成和相等的兩部分

給你一個 只包含正整數 的 非空 陣列 nums ,請你判斷是否可以將這個陣列分割成兩個子集,使得兩個子集的元素和相等,

輸入:nums = [1,5,11,5]
輸出:true
解釋:陣列可以分割成 [1, 5, 5] 和 [11] ,
輸入:nums = [1,2,3,5]
輸出:false
解釋:陣列不能分割成兩個元素和相等的子集,

在這里插入圖片描述

class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int sum = accumulate(nums.begin(), nums.end(), 0);
        if(sum & 1) return false; 
        int target = sum/2;
        if(*max_element(nums.begin(), nums.end()) > target) return false;

        vector<vector<bool>> dp(nums.size(), vector<bool>(target+1, false));
        dp[0][nums[0]] = true; // 第一行的第nums[0]列為true 初始化, 因為一個物品放到背包中正好等于背包容積
        for(int i=1; i<nums.size(); i++){
            for(int j=1; j<=target; j++){
                if(nums[i] > j) dp[i][j] = dp[i-1][j]; // 當前物體容積太大, 不取, 則跟上面的一樣
                else if(nums[i] == j) dp[i][j] = true; // 當前值正好等于背包容積
                else{
                    // 當前值小于背包容積, 放進去的話是dp[i-1][j-nums[i]], 不放進去的話是dp[i-1][j]
                    dp[i][j] = dp[i-1][j-nums[i]] | dp[i-1][j]; 
                }
            }
        }
        return dp[nums.size()-1][target];
    }
};

4.2 完全背包問題

在這里插入圖片描述

int knapsack_fully(vector<int> weights, vector<int> values, int N, int W) {
	std::vector<std::vector<int>> dp(N+1, std::vector<int>(W+1, 0));
	int w,v;
	for(int i=1; i<=N; i++){
		w=weights[i-1], v=values[i-1];
		for(int j = 1; j<=W; j++){
			if(j>=w){  
				dp[i][j] = max(dp[i-1][j], v+dp[i][j-w]);
			}else{
				dp[i][j] = dp[i-1][j];
			}
		}
	}
	print_vv(dp);
	return dp[N][W];
}

5. 分割問題

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

標籤:其他

上一篇:C語言學習 -- 函式堆疊幀的創建和銷毀

下一篇: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