華為OD機試真題——最小的調整次數/特異性雙端隊列(2025A卷:100分)Java/python/JavaScript/C++/C語言/GO六種最佳實現

在這里插入圖片描述

2025 A卷 100分 題型

本文涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、測試用例以及綜合分析;
并提供Java、python、JavaScript、C++、C語言、GO六種語言的最佳實現方式!

2025華為OD真題目錄+全流程解析/備考攻略/經驗分享

華為OD機試真題《最小的調整次數/特異性雙端隊列》:


目錄

    • 題目名稱:最小的調整次數/特異性雙端隊列
      • 題目描述
    • Java
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • python
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • JavaScript
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • C++
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • C語言
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • GO
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • 更多內容:


題目名稱:最小的調整次數/特異性雙端隊列


屬性內容
知識點雙端隊列、邏輯處理
時間限制1秒
空間限制256MB
限定語言不限

題目描述

有一個特異性的雙端隊列,該隊列可以從頭部或尾部添加數據,但只能從頭部移出數據。小A依次執行2n個指令(n個添加操作和n個移除操作)。添加指令按順序插入1到n的數值(可能從頭部或尾部添加),移除指令要求按1到n的順序移出元素。在任何時刻可以調整隊列數據順序,求最少的調整次數以滿足移除順序要求。

輸入描述

  • 第一行輸入整數n(1 ≤ n ≤ 3×10?)。
  • 后續2n行包含n條添加指令(head add xtail add x)和n條remove指令。

輸出描述
輸出一個整數,表示最小調整次數。

示例
輸入:

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出:

1  

解釋:
移除順序需為1→2→3→4→5。在第7步移除時隊列頭部為2,需調整順序后移出,調整次數+1。


Java

問題分析

我們需要處理一個特異性的雙端隊列,每次添加元素可以選擇頭部或尾部,但只能從頭部移除元素。目標是按順序移除元素1到n,并在必要時調整隊列順序,求出最小的調整次數。

解題思路

  1. 維護連續區間:跟蹤當前連續的右邊界 currentMax,表示當前連續遞增序列的最大值。
  2. 添加操作處理:如果添加的元素是 currentMax + 1 且添加到尾部,擴展連續區間;否則標記隊列為無序。
  3. 移除操作處理:若隊列頭部是當前期望值 expected,直接移除;否則調整隊列,調整次數加一,并重置連續區間。

代碼實現

import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();sc.nextLine();int expected = 1;int currentMax = 0;int adjusts = 0;boolean ordered = true;for (int i = 0; i < 2 * n; i++) {String line = sc.nextLine().trim();if (line.startsWith("remove")) {if (ordered && expected == currentMax) {expected++;currentMax = 0;} else {adjusts++;expected++;currentMax = 0;ordered = true;}} else {int x = Integer.parseInt(line.split(" ")[2]);if (ordered) {if (x == currentMax + 1) {currentMax = x;} else {ordered = false;currentMax = Math.max(currentMax, x);}} else {currentMax = Math.max(currentMax, x);}}}System.out.println(adjusts);}
}

代碼詳細解析

  1. 輸入處理:讀取n和后續的2n條指令。
  2. 變量初始化
    • expected:下一個需要移除的元素,初始為1。
    • currentMax:當前連續區間的最大值,初始為0。
    • adjusts:調整次數計數器。
    • ordered:標記隊列是否處于有序狀態。
  3. 處理每條指令
    • 移除指令
      • 若隊列有序且當前expected等于currentMax(即頭部為expected),則直接移除。
      • 否則調整次數加一,重置currentMax并標記隊列為有序。
    • 添加指令
      • 若隊列有序且新元素是currentMax + 1,擴展連續區間。
      • 否則標記隊列為無序,并更新currentMax

示例測試

示例輸入

5
head add 1
tail add 2
remove
head add 3
tail add 4
head add 5
remove
remove
remove
remove

輸出

1

解析:在第3步移除時隊列頭部不是1,調整次數加一。后續移除操作無需調整。

另一個測試用例

3
head add 3
tail add 1
remove
tail add 2
remove
remove

輸出

2

解析:第一次移除時隊列頭部是3≠1,調整一次;第二次移除時頭部是1≠2,調整第二次。

綜合分析

  1. 時間復雜度:O(n),每個指令處理時間為O(1)。
  2. 空間復雜度:O(1),僅維護幾個變量。
  3. 優勢:無需模擬隊列操作,直接通過邏輯判斷調整次數,高效處理大規模數據。
  4. 適用性:適用于任何n值,尤其適合高并發和大數據場景。

python

問題分析

我們需要處理一個特異性的雙端隊列,隊列可以從頭部或尾部添加元素,但只能從頭部移除元素。目標是按順序移除1到n的元素,并在必要時調整隊列順序,求出最小的調整次數。

解題思路

  1. 維護連續區間:跟蹤當前連續的右邊界 current_max,表示當前可連續移除的最大值。
  2. 全局最大值:維護 global_max 記錄所有已添加元素的最大值。
  3. 調整條件:當需要移除的元素 expected 超過 current_max 時,必須調整隊列,調整次數加一,并將 current_max 更新為 global_max

代碼實現

n = int(input())
expected = 1
current_max = 0
global_max = 0
adjusts = 0for _ in range(2 * n):line = input().strip()if line.startswith('remove'):if expected > current_max:adjusts += 1current_max = global_maxexpected += 1else:x = int(line.split()[2])global_max = max(global_max, x)if x == current_max + 1:current_max = xprint(adjusts)

代碼詳細解析

  1. 輸入處理:讀取 n 和后續的2n條指令。
  2. 初始化變量
    • expected:下一個需要移除的元素,初始為1。
    • current_max:當前連續區間的最大值,初始為0。
    • global_max:所有已添加元素的最大值,初始為0。
    • adjusts:調整次數計數器。
  3. 處理指令
    • 移除指令:若 expected 超過 current_max,調整次數加一,current_max 設為 global_max,隨后 expected 遞增。
    • 添加指令:更新 global_max,若元素是 current_max + 1,擴展連續區間。
  4. 輸出結果:打印總調整次數。

示例測試

示例輸入

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出

1

解析

  • 前三次操作后,current_max=2expected=2
  • 添加3、4、5后,current_max 保持2,global_max=5
  • 第四次移除時,expected=3 > current_max=2,調整次數加一,current_max 設為5,后續移除無需調整。

另一個測試用例

3  
head add 3  
tail add 1  
remove  
tail add 2  
remove  
remove  

輸出

2

解析

  • 首次移除時,expected=1 > current_max=0,調整一次。
  • 第二次移除時,expected=2 > current_max=3(調整后 current_max=3),調整第二次。

綜合分析

  1. 時間復雜度:O(n),每個指令處理時間為O(1)。
  2. 空間復雜度:O(1),僅維護幾個變量。
  3. 優勢:無需模擬隊列操作,通過維護連續區間和全局最大值高效判斷調整條件。
  4. 適用場景:適用于大規模數據,時間復雜度為線性,滿足題目約束。

JavaScript

問題分析

我們需要處理一個特異性的雙端隊列,隊列可以從頭部或尾部添加元素,但只能從頭部移除元素。目標是在執行一系列添加和移除操作后,統計最小的調整次數,使得移除順序為1到n。


解題思路

  1. 維護連續區間:跟蹤當前連續的右邊界 currentMax,表示當前可以連續移除的最大值。
  2. 全局最大值:維護 globalMax 記錄所有已添加元素的最大值。
  3. 調整條件:當需要移除的元素 expected 超過 currentMax 時,必須調整隊列,調整次數加一,并將 currentMax 更新為 globalMax

代碼實現

const readline = require('readline');const rl = readline.createInterface({input: process.stdin,output: process.stdout,terminal: false
});let n;
let expected = 1;
let currentMax = 0;
let globalMax = 0;
let adjusts = 0;
let lineCount = 0;rl.on('line', (line) => {if (lineCount === 0) {n = parseInt(line.trim());} else {const trimmedLine = line.trim();if (trimmedLine.startsWith('remove')) {if (expected > currentMax) {adjusts++;currentMax = globalMax;}expected++;} else {const x = parseInt(trimmedLine.split(' ')[2], 10);globalMax = Math.max(globalMax, x);if (x === currentMax + 1) {currentMax = x;}}}lineCount++;if (lineCount === 2 * n + 1) {console.log(adjusts);rl.close();}
});

代碼詳細解析

  1. 輸入處理:使用 readline 逐行讀取輸入,第一行為 n
  2. 變量初始化
    • expected:下一個需要移除的元素,初始為1。
    • currentMax:當前可連續移除的最大值,初始為0。
    • globalMax:所有已添加元素的最大值,初始為0。
    • adjusts:調整次數計數器。
  3. 處理指令
    • 移除指令:若 expected > currentMax,調整次數加一,currentMax 設為 globalMax
    • 添加指令:更新 globalMax,若元素是 currentMax + 1,擴展 currentMax
  4. 輸出結果:在所有指令處理完畢后輸出調整次數。

示例測試

示例輸入

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出

1

解析

  • 前三次操作后,currentMax=2expected=2
  • 添加3、4、5后,currentMax=5
  • 第四次移除時,expected=2 不超過 currentMax,無需調整。
  • 最后一次移除時,expected=5 超過 currentMax,調整次數加一。

另一個測試用例

3  
head add 3  
tail add 1  
remove  
tail add 2  
remove  
remove  

輸出

2

解析

  • 首次移除時,expected=1 > currentMax=0,調整一次。
  • 第二次移除時,expected=2 > currentMax=3,調整第二次。

綜合分析

  1. 時間復雜度:O(n),每個指令處理時間為O(1)。
  2. 空間復雜度:O(1),僅維護幾個變量。
  3. 優勢:無需模擬隊列操作,通過維護連續區間和全局最大值高效判斷調整條件。
  4. 適用場景:適用于大規模數據,時間復雜度為線性,滿足題目約束。

C++

問題分析

我們需要處理一個特異性的雙端隊列,隊列只能從頭部或尾部添加元素,但移除只能從頭部。目標是按順序移除1到n的元素,計算最小調整次數。調整指的是重新排列隊列,使頭部元素為當前期望值。

解題思路

  1. 維護連續區間:跟蹤當前可以連續移除的最大值 current_max,所有已添加元素的最大值 global_max
  2. 添加操作:若添加元素等于 current_max + 1,則擴展連續區間;否則更新 global_max
  3. 移除操作:若期望值超過 current_max,則調整隊列,將 current_max 設為 global_max,調整次數加一。

代碼實現

#include <iostream>
#include <vector>
#include <string>
#include <sstream>
using namespace std;int main() {int n;cin >> n;cin.ignore(); // 忽略換行符int expected = 1; // 期望移除的下一個元素int current_max = 0; // 當前連續區間的最大值int global_max = 0; // 所有已添加元素的最大值int adjusts = 0; // 調整次數string line;for (int i = 0; i < 2 * n; ++i) {getline(cin, line);if (line.substr(0, 6) == "remove") {// 移除操作if (expected > current_max) {adjusts++;current_max = global_max;}expected++;} else {// 解析添加的值istringstream iss(line);string part, op;int x;iss >> part >> op >> x;// 更新全局最大值global_max = max(global_max, x);// 若元素是當前連續區間的下一個值,擴展區間if (x == current_max + 1) {current_max = x;}}}cout << adjusts << endl;return 0;
}

代碼詳細解析

  1. 輸入處理:讀取n并忽略換行符。
  2. 初始化變量
    • expected:下一個期望移除的元素,初始為1。
    • current_max:當前連續區間的最大值,初始為0。
    • global_max:所有已添加元素的最大值,初始為0。
    • adjusts:調整次數計數器。
  3. 處理每條指令
    • 移除指令:若期望值超過 current_max,調整次數加一,current_max 更新為 global_max
    • 添加指令:更新 global_max,若元素是 current_max + 1,則擴展連續區間。
  4. 輸出結果:最終打印調整次數。

示例測試

示例輸入

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出

1

解析

  • 添加1和2后,current_max=2
  • 第一次移除后,expected=2
  • 添加3、4、5后,current_max=5
  • 后續移除無需調整,僅在第4步移除時調整一次。

另一個測試用例

3  
head add 3  
tail add 1  
remove  
tail add 2  
remove  
remove  

輸出

2

解析

  • 首次移除3時需調整(期望1)。
  • 移除1后,期望2超過 current_max=1,再次調整。

綜合分析

  1. 時間復雜度:O(n),每個指令處理時間為O(1)。
  2. 空間復雜度:O(1),僅維護幾個變量。
  3. 優勢:無需模擬隊列操作,通過維護連續區間和全局最大值高效判斷調整條件。
  4. 適用性:適用于大規模數據,時間復雜度為線性,滿足題目約束。

C語言

問題分析

我們需要處理一個特異性的雙端隊列,隊列只能從頭部或尾部添加元素,但移除只能從頭部。目標是按順序移除1到n的元素,計算最小調整次數。調整指的是重新排列隊列,使頭部元素為當前期望值。

解題思路

  1. 維護連續區間:跟蹤當前可以連續移除的最大值 current_max,所有已添加元素的最大值 global_max
  2. 添加操作:若添加元素等于 current_max + 1,則擴展連續區間;否則更新 global_max
  3. 移除操作:若期望值超過 current_max,則調整隊列,將 current_max 設為 global_max,調整次數加一。

代碼實現

#include <stdio.h>
#include <string.h>
#include <stdlib.h>#define MAX_LINE_LENGTH 20 // 每行指令最大長度int main() {int n;scanf("%d", &n);getchar(); // 讀取換行符int expected = 1;   // 期望移除的下一個元素int current_max = 0; // 當前連續區間的最大值int global_max = 0;  // 所有已添加元素的最大值int adjusts = 0;     // 調整次數計數器char line[MAX_LINE_LENGTH];for (int i = 0; i < 2 * n; i++) {fgets(line, MAX_LINE_LENGTH, stdin);line[strcspn(line, "\n")] = '\0'; // 去除換行符if (strcmp(line, "remove") == 0) { // 移除指令if (expected > current_max) {  // 需要調整adjusts++;current_max = global_max;}expected++;} else { // 添加指令(head add x 或 tail add x)int x;sscanf(line + 8, "%d", &x); // 跳過"head add "或"tail add "// 更新全局最大值if (x > global_max) global_max = x;// 檢查是否擴展連續區間if (x == current_max + 1) {current_max = x;}}}printf("%d\n", adjusts);return 0;
}

代碼詳細解析

  1. 輸入讀取

    scanf("%d", &n);
    getchar(); // 處理輸入n后的換行符
    
    • 讀取n后,必須用getchar()清除輸入緩沖區中的換行符,避免影響后續fgets讀取。
  2. 變量初始化

    int expected = 1;     // 下一個期望移除的元素(初始為1)
    int current_max = 0;  // 當前連續區間的最大值(初始為0)
    int global_max = 0;   // 全局最大值(初始為0)
    int adjusts = 0;      // 調整次數計數器
    
  3. 處理每條指令

    fgets(line, MAX_LINE_LENGTH, stdin);
    line[strcspn(line, "\n")] = '\0'; // 去除末尾換行符
    
    • fgets讀取整行指令,包括換行符,通過strcspn找到換行符位置并替換為終止符。
  4. 移除指令處理

    if (strcmp(line, "remove") == 0) {if (expected > current_max) { // 需要調整adjusts++;current_max = global_max;}expected++;
    }
    
    • 當期望值expected超過current_max時,必須調整隊列,更新current_maxglobal_max,并增加調整次數。
  5. 添加指令處理

    sscanf(line + 8, "%d", &x); // 跳過指令前綴(head add 或 tail add)
    if (x > global_max) global_max = x;
    if (x == current_max + 1) {current_max = x;
    }
    
    • 從指令字符串的第8個字符開始解析數值(跳過head add tail add 共8字符)。
    • 更新全局最大值global_max
    • 若元素是current_max + 1,則擴展連續區間。

示例測試

示例輸入

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出

1

解析

  1. 添加1和2后,current_max=2
  2. 第一次remove時,expected=1 <= current_max=2,無需調整。
  3. 添加3、4、5后,current_max保持2(因為3不是連續的)。
  4. 后續remove操作中,當expected=3 > current_max=2,觸發調整,adjusts=1current_max=5
  5. 后續操作無需調整,最終總調整次數為1。

另一個測試用例

3  
head add 3  
tail add 1  
remove  
tail add 2  
remove  
remove  

輸出

2

解析

  1. 第一次remove時,expected=1 > current_max=0,調整次數+1,current_max=3
  2. 第二次remove時,expected=2 > current_max=3,調整次數+1,current_max=3
  3. 總調整次數為2。

綜合分析

  1. 時間復雜度:O(n)

    • 每條指令處理時間為O(1),總共有2n條指令,時間復雜度為O(n)。
  2. 空間復雜度:O(1)

    • 僅使用固定數量的變量,不隨輸入規模增長。
  3. 優勢

    • 無需模擬隊列:通過維護current_maxglobal_max,避免了實際隊列操作的復雜度。
    • 高效判斷調整條件:直接通過數值比較確定是否需要調整,時間復雜度為O(1)。
  4. 適用場景

    • 輸入規模大(n ≤ 3×10?)時,依然保持高效。
    • 適用于需要快速判斷調整條件的場景,如實時系統或高頻交易。

GO

問題分析

我們需要處理一個特異性的雙端隊列,隊列只能從頭部或尾部添加元素,但移除只能從頭部。目標是按順序移除1到n的元素,計算最小調整次數。調整指的是重新排列隊列,使頭部元素為當前期望值。

解題思路

  1. 維護連續區間:跟蹤當前可以連續移除的最大值 currentMax,所有已添加元素的最大值 globalMax
  2. 添加操作:若添加元素等于 currentMax + 1,則擴展連續區間;否則更新 globalMax
  3. 移除操作:若期望值超過 currentMax,則調整隊列,將 currentMax 設為 globalMax,調整次數加一。

代碼實現

package mainimport ("bufio""fmt""os""strconv""strings"
)func main() {scanner := bufio.NewScanner(os.Stdin)// 讀取nscanner.Scan()n, _ := strconv.Atoi(scanner.Text())expected := 1       // 期望的下一個移除元素(初始為1)currentMax := 0    // 當前連續區間的最大值globalMax := 0     // 所有已添加元素的最大值adjusts := 0       // 調整次數計數器// 處理2n條指令for i := 0; i < 2*n; i++ {scanner.Scan()line := scanner.Text()if line == "remove" {// 移除操作:檢查是否需要調整if expected > currentMax {adjusts++currentMax = globalMax}expected++} else {// 解析添加操作中的數值(格式:head add x 或 tail add x)parts := strings.Split(line, " ")x, _ := strconv.Atoi(parts[2])// 更新全局最大值if x > globalMax {globalMax = x}// 若元素是連續區間的下一個值,擴展區間if x == currentMax + 1 {currentMax = x}}}fmt.Println(adjusts)
}

代碼詳細解析

  1. 輸入處理

    • 使用 bufio.Scanner 逐行讀取輸入,第一行為 n
    • 初始化關鍵變量:
      • expected:下一個期望移除的元素,初始為1。
      • currentMax:當前連續區間的最大值,初始為0。
      • globalMax:所有已添加元素的最大值,初始為0。
      • adjusts:調整次數計數器。
  2. 處理指令

    for i := 0; i < 2*n; i++ {scanner.Scan()line := scanner.Text()
    
    • 循環讀取每條指令(共 2n 條)。
  3. 移除操作

    if line == "remove" {if expected > currentMax {adjusts++currentMax = globalMax}expected++
    }
    
    • 當需要移除的 expected 超過 currentMax 時,必須調整隊列。
    • 調整次數加一,并將 currentMax 設為 globalMax
    • expected 遞增,準備處理下一個元素。
  4. 添加操作

    parts := strings.Split(line, " ")
    x, _ := strconv.Atoi(parts[2])if x > globalMax {globalMax = x
    }if x == currentMax + 1 {currentMax = x
    }
    
    • 解析添加操作中的數值(如 head add 1 中的 1)。
    • 更新 globalMax 為所有已添加元素的最大值。
    • 若當前元素是 currentMax + 1,則擴展連續區間。

示例測試

示例輸入

5  
head add 1  
tail add 2  
remove  
head add 3  
tail add 4  
head add 5  
remove  
remove  
remove  
remove  

輸出

1

解析

  • 添加1和2后,currentMax=2
  • 第一次移除時,expected=1 <= currentMax=2,無需調整。
  • 添加3、4、5時,globalMax=5,但 currentMax 保持2(因為3不連續)。
  • 當移除 expected=3 時,觸發調整,adjusts=1currentMax=5
  • 后續移除操作無需調整。

另一個測試用例

3  
head add 3  
tail add 1  
remove  
tail add 2  
remove  
remove  

輸出

2

解析

  • 添加3和1后,globalMax=3,但 currentMax=0(元素不連續)。
  • 第一次移除時,expected=1 > currentMax=0,調整次數+1,currentMax=3
  • 第二次移除時,expected=2 > currentMax=3,調整次數+1。
  • 總調整次數為2。

綜合分析

  1. 時間復雜度:O(n)

    • 每條指令處理時間為O(1),總共有2n條指令,時間復雜度為O(n)。
  2. 空間復雜度:O(1)

    • 僅使用固定數量的變量,不隨輸入規模增長。
  3. 優勢

    • 無需模擬隊列:通過維護 currentMaxglobalMax,避免了實際隊列操作的復雜度。
    • 高效判斷調整條件:直接通過數值比較確定是否需要調整,時間復雜度為O(1)。
  4. 適用場景

    • 輸入規模大(n ≤ 3×10?)時,依然保持高效。
    • 適用于需要快速判斷調整條件的場景,如實時系統或高頻交易。

更多內容:

https://www.kdocs.cn/l/cvk0eoGYucWA

本文發表于【紀元A夢】,關注我,獲取更多實用教程/資源!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/77211.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/77211.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/77211.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

關于 Spring Boot 微服務解決方案的對比,并以 Spring Cloud Alibaba 為例,詳細說明其核心組件的使用方式、配置及代碼示例

以下是關于 Spring Boot 微服務解決方案的對比&#xff0c;并以 Spring Cloud Alibaba 為例&#xff0c;詳細說明其核心組件的使用方式、配置及代碼示例&#xff1a; 關于 Spring Cloud Alibaba 致力于提供微服務開發的一站式解決方案! https://sca.aliyun.com/?spm7145af80…

常見的爬蟲算法

1.base64加密 base64是什么 Base64編碼&#xff0c;是由64個字符組成編碼集&#xff1a;26個大寫字母AZ&#xff0c;26個小寫字母az&#xff0c;10個數字0~9&#xff0c;符號“”與符號“/”。Base64編碼的基本思路是將原始數據的三個字節拆分轉化為四個字節&#xff0c;然后…

B樹、紅黑樹、B+樹和平衡二叉樹(如AVL樹)的區別

B樹、紅黑樹、B樹和平衡二叉樹&#xff08;如AVL樹&#xff09;的區別及優缺點的總結&#xff1a; 1. 平衡二叉樹&#xff08;AVL樹&#xff09; 結構&#xff1a;二叉搜索樹&#xff0c;每個節點的左右子樹高度差不超過1。平衡方式&#xff1a;通過旋轉&#xff08;左旋/右旋…

Python Cookbook-6.5 繼承的替代方案——自動托管

任務 你需要從某個類或者類型繼承&#xff0c;但是需要對繼承做一些調整。比如&#xff0c;需要選擇性地隱藏某些基類的方法&#xff0c;而繼承并不能做到這一點。 解決方案 繼承是很方便的&#xff0c;但它并不是萬用良藥。比如&#xff0c;它無法讓你隱藏基類的方法或者屬…

長短期記憶網絡:從理論到創新應用的深度剖析

一、引言 1.1 研究背景 深度學習在人工智能領域的發展可謂突飛猛進&#xff0c;而長短期記憶網絡&#xff08;LSTM&#xff09;在其中占據著至關重要的地位。隨著數據量的不斷增長和對時序數據處理需求的增加&#xff0c;傳統的神經網絡在處理長序列數據時面臨著梯度消失和梯…

vue3.2 + element-plus 實現跟隨input輸入框的彈框,彈框里可以分組或tab形式顯示選項

效果 基礎用法&#xff08;分組選項&#xff09; 高級用法&#xff08;帶Tab欄&#xff09; <!-- 彈窗跟隨通用組件 SmartSelector.vue --> <!-- 彈窗跟隨通用組件 --> <template><div class"smart-selector-container"><el-popove…

C語言中冒泡排序和快速排序的區別

冒泡排序和快速排序都是常見的排序算法&#xff0c;但它們在原理、效率和應用場景等方面存在顯著區別。以下是兩者的詳細對比&#xff1a; 一、算法原理 1. 冒泡排序 原理&#xff1a;通過重復遍歷數組&#xff0c;比較相鄰元素的大小&#xff0c;并在必要時交換它們的位置。…

軟件信息安全性測試如何進行?有哪些注意事項?

隨著信息技術的高速發展&#xff0c;軟件已經成為我們生活和工作中不可或缺的一部分。然而&#xff0c;隨著軟件產品的廣泛普及&#xff0c;軟件信息安全性問題也日益凸顯&#xff0c;因此軟件信息安全性測試必不可少。那么軟件信息安全性測試應如何進行呢?在進行過程中又有哪…

springboot集成mybaits-generator自動生成代碼

文章目錄 概述創建springboot項目pom文件aplication.yml代碼生成類mybatis-plus提供的變量controller模板mapper模板總結 概述 創建springboot項目&#xff0c;在這里使用的是springboot 2.6.13版本&#xff0c;引入的項目依賴包如pom文件所寫&#xff0c;jdk使用1.8&#xff…

數據庫脫褲

假設你已經getshell 找到mysql賬號密碼。 網站要連接mysql&#xff0c;就需要把mysql的賬號密碼保存在一個php文件中&#xff0c;類似config.php、common.inc.php等&#xff0c;在shell中&#xff0c;讀取這些文件&#xff0c;找到其中信息即可 下面是一些常見平臺的配置文…

leetcode 337. House Robber III

用動態規劃的思想解決這道題。 對于每一個節點&#xff0c;只有兩種可能&#xff0c;偷或者不偷。 對于一顆以root為根節點的二叉樹&#xff0c;定義rob表示偷root節點能從這棵二叉樹偷到的最大金額。定義notrob表示不偷root節點能從這棵二叉樹偷到的最大金額。 遞推公式分析…

ES和MySQL概念對比

基本概念 ES和MySQL都屬于數據庫&#xff0c;不過各有各的特性&#xff0c;大致使用方法與MySQL類似并無區別。 MySQL&#xff1a;擅長事務持有ACID的特性&#xff0c;確保數據的一致性和安全。 ES&#xff1a;持有倒排索引&#xff0c;適合海量數據搜索和分析。 ES和MySQL如何…

【python】針對Selenium中彈框信息無法定位的問題,以下是綜合解決方案及注意事項:

一、常見原因分析 1.1 彈窗類型不匹配 若彈窗為alert&#xff0c;需使用driver.switch_to.alert處理&#xff1b; 若為confirm或prompt&#xff0c;同樣適用該方法。 1.2 窗口句柄切換問題 新窗口或彈窗可能開啟新句柄&#xff0c;需先通過driver.window_handles切換到對應句…

歐拉服務器操作系統安裝MySQL

1. 安裝MySQL服務器?? 1. 更新倉庫緩存 sudo dnf makecache2. 安裝MySQL sudo dnf install mysql-server2. 初始化數據庫? sudo mysqld --initialize --usermysql3. 啟動數據庫服務 # 啟動服務 sudo systemctl start mysqld# 設置開機自啟 sudo systemctl enable mysql…

SQLark:一款國產免費數據庫開發和管理工具

SQLark&#xff08;百靈連接&#xff09;是一款面向信創應用開發者的數據庫開發和管理工具&#xff0c;用于快速查詢、創建和管理不同類型的數據庫系統&#xff0c;目前可以支持達夢數據庫、Oracle 以及 MySQL。 對象管理 SQLark 支持豐富的數據庫對象管理功能&#xff0c;包括…

Spring Boot 中的自動配置原理

2025/4/6 向全棧工程師邁進&#xff01; 一、自動配置 所謂的自動配置原理就是遵循約定大約配置的原則&#xff0c;在boot工程程序啟動后&#xff0c;起步依賴中的一些bean對象會自動的注入到IOC容器中。 在講解Spring Boot 中bean對象的管理的時候&#xff0c;我們注入bean對…

Mysql8配置文件

Mysql8配置文件 修改my.cnf----配置持久化鍵(persistence key)配置表名不區分大小寫 修改my.cnf----配置持久化鍵(persistence key) MySQL8初始化數據庫之前配置好這些變量值&#xff0c;初始化數據庫之后可能無法修改這個值。 # 服務端配置 [mysqld] ######## 數據目錄和基…

關于系統架構思考,如何設計實現系統的高可用?

緒論、系統高可用的必要性 系統高可用為了保持業務連續性保障&#xff0c;以及停機成本量化&#xff0c;比如在以前的雙十一當天如果出現宕機&#xff0c;那將會損失多少錢&#xff1f;比如最近幾年Amazon 2021年30分鐘宕機損失$5.6M。當然也有成功的案例&#xff0c;比如異地…

【Unity筆記】實現可視化配置的Unity按鍵輸入管理器(按下/長按/松開事件 + UnityEvent綁定)

【Unity筆記】實現可視化配置的Unity按鍵輸入管理器 適用于角色控制、技能觸發的Unity按鍵輸入系統&#xff0c;支持UnityEvent事件綁定、長按/松開監聽與啟用開關 一、引言 在 Unity 游戲開發中&#xff0c;處理鍵盤輸入是最常見的交互方式之一。尤其是角色控制、技能釋放、菜…

Fortran 中使用 C_LOC 和 C_F_POINTER 結合的方法來實現不同類型指針指向同一塊內存區域

在 Fortran 中&#xff0c;可以使用 C_LOC 和 C_F_POINTER 結合的方法來實現不同類型指針指向同一塊內存區域。以下是具體方法和示例&#xff1a; 關鍵步驟&#xff1a; 獲取內存地址&#xff1a;用 C_LOC 獲取原始數組的 C 地址。類型轉換&#xff1a;用 C_F_POINTER 將地址轉…