华为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秒
空间限制:32MB
限定语言:不限


题目描述

给定两个数组A和B,统计满足A[i] == B[j]的二元组(i,j)的总个数。

输入描述

  • 第一行输入数组A的长度M
  • 第二行输入数组B的长度N
  • 第三行输入数组A的元素(空格分隔)
  • 第四行输入数组B的元素(空格分隔)

输出描述
输出匹配的二元组个数。若不存在匹配,输出0。

示例1
输入:

5  
4  
1 2 3 4 5  
4 3 2 1  

输出:

4  

示例2
输入:

6  
3  
1 2 4 4 2 1  
1 2 3  

输出:

4  

Java

问题分析

我们需要统计两个数组A和B中满足A[i] == B[j]的二元组(i,j)的总个数。直接遍历所有可能的组合会导致时间复杂度为O(M*N),但通过哈希表优化可以将时间复杂度降低到O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组A,用哈希表记录每个元素出现的次数。
  2. 遍历数组B匹配:遍历数组B,对于每个元素,在哈希表中查找其出现次数并累加。

代码实现

import java.util.*;
import java.io.*;public class Main {public static void main(String[] args) throws IOException {// 使用BufferedReader读取输入,避免Scanner的换行符问题BufferedReader br = new BufferedReader(new InputStreamReader(System.in));// 读取数组A和B的长度int M = Integer.parseInt(br.readLine());int N = Integer.parseInt(br.readLine());// 读取数组A的元素并转换为整型数组String[] aParts = br.readLine().split(" ");int[] a = new int[M];for (int i = 0; i < M; i++) {a[i] = Integer.parseInt(aParts[i]);}// 读取数组B的元素并转换为整型数组String[] bParts = br.readLine().split(" ");int[] b = new int[N];for (int i = 0; i < N; i++) {b[i] = Integer.parseInt(bParts[i]);}// 创建哈希表统计数组A中每个元素的出现次数Map<Integer, Integer> countMap = new HashMap<>();for (int num : a) {countMap.put(num, countMap.getOrDefault(num, 0) + 1);}// 遍历数组B,累加匹配次数int result = 0;for (int num : b) {result += countMap.getOrDefault(num, 0);}// 输出结果System.out.println(result);}
}

代码详细解析

  1. 读取输入

    • BufferedReader逐行读取输入,避免Scanner的换行符问题。
    • 前两行读取数组A和B的长度MN
    • 第三行读取数组A的元素并转换为整型数组。
    • 第四行读取数组B的元素并转换为整型数组。
  2. 统计数组A的元素频率

    • 使用HashMap存储数组A中每个元素及其出现次数。
    • countMap.getOrDefault(num, 0)确保元素不存在时返回0。
  3. 遍历数组B计算匹配次数

    • 对数组B中的每个元素,查找其在哈希表中的出现次数。
    • 累加所有匹配次数,得到最终结果。

示例测试

示例1输入

5
4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • 数组A中每个元素出现1次,数组B中的元素4、3、2、1均能在A中找到,总共有4对。

示例2输入

6
3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • 数组A中1出现2次、2出现2次,数组B中的1和2分别匹配2次,总共有4次。

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次。
    • 匹配计算:O(N),遍历数组B一次。
    • 总复杂度:O(M + N),线性时间复杂度。
  2. 空间复杂度

    • 哈希表存储:O(M),存储数组A中所有不同元素及其频率。
  3. 优势

    • 高效性:相比暴力法的O(M*N),哈希表将复杂度优化到O(M + N)。
    • 代码简洁:逻辑清晰,易于理解和维护。
  4. 适用场景

    • 处理大规模数据时,哈希表方法能显著提升性能。
    • 适用于需要快速查找元素出现次数的场景。

python

问题分析

我们需要统计两个数组A和B中满足A[i] == B[j]的二元组(i,j)的总个数。直接遍历所有可能的组合会导致时间复杂度为O(M*N),但通过哈希表优化可以将时间复杂度降低到O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组A,用字典记录每个元素出现的次数。
  2. 遍历数组B匹配:遍历数组B,对于每个元素,在字典中查找其出现次数并累加。

代码实现

def main():import sys# 读取输入数据m = int(sys.stdin.readline())       # 读取数组A的长度n = int(sys.stdin.readline())       # 读取数组B的长度# 读取数组A的元素并转换为整数列表a = list(map(int, sys.stdin.readline().split()))# 验证数组长度是否匹配输入值if len(a) != m:print(0)return# 读取数组B的元素并转换为整数列表b = list(map(int, sys.stdin.readline().split()))# 验证数组长度是否匹配输入值if len(b) != n:print(0)return# 创建字典统计数组A中每个元素的出现次数count_dict = {}for num in a:# 如果元素存在,计数+1;不存在则初始化为0后+1count_dict[num] = count_dict.get(num, 0) + 1# 遍历数组B,统计总匹配次数total = 0for num in b:# 从字典中获取该元素的出现次数(默认0次)total += count_dict.get(num, 0)print(total)if __name__ == "__main__":main()

代码详细解析

  1. 输入处理

    • sys.stdin.readline() 逐行读取输入,避免缓冲区问题
    • mn 分别读取数组A和B的长度
    • a = list(map(...)) 将输入行分割为字符串列表并转换为整数列表
    • 验证数组长度是否与输入值一致,防止数据错误
  2. 频率统计字典

    • 创建空字典 count_dict 存储元素频率
    • count_dict.get(num, 0) 是字典的安全访问方法:
      • 当元素存在时返回当前计数值
      • 不存在时返回默认值0
    • 遍历数组A时,每个元素计数+1
  3. 匹配计算

    • 遍历数组B的每个元素
    • count_dict.get(num, 0) 获取该元素在A中的出现次数
    • 所有匹配次数累加到total
  4. 边界处理

    • 数组长度验证防止数据格式错误
    • 不存在的元素自动按0次处理

示例测试

示例1输入

5
4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • A中每个元素出现1次
  • B中的4、3、2、1均能在A中找到
  • 总匹配次数 = 1+1+1+1 = 4

示例2输入

6
3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • A中1出现2次,2出现2次,4出现2次
  • B中的1匹配2次,2匹配2次,3匹配0次
  • 总匹配次数 = 2+2+0 = 4

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次
    • 匹配计算:O(N),遍历数组B一次
    • 总复杂度:O(M + N),线性时间复杂度
  2. 空间复杂度

    • 字典存储:最差O(M)(所有元素不同时)
    • 输入存储:O(M + N) 存储两个数组
  3. 性能优势

    • 相比暴力法的O(M*N),效率提升数百倍
    • 例如当M=N=105时,暴力法需1010次运算(不可行),而哈希法仅需2*10^5次
  4. 适用场景

    • 大规模数据处理(如M=1e6, N=1e6)
    • 需要频繁查询元素出现次数的场景
    • 元素取值范围较大的情况(哈希表不依赖连续空间)
  5. Python特性利用

    • 字典的get()方法简化了"存在性检查+默认值"逻辑
    • map()函数高效处理类型转换
    • 动态列表自动处理变长数据
  6. 扩展性

    • 支持非整数类型(只需可哈希)
    • 可轻松修改为统计三元组、四元组等
    • 适用于分布式计算(分块统计频率后合并)

JavaScript

问题分析

我们需要统计两个数组 A 和 B 中满足 A[i] == B[j] 的二元组 (i, j) 的总个数。直接遍历所有组合的时间复杂度为 O(M*N),但通过哈希表优化可以将时间复杂度降低到 O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组 A,用哈希表记录每个元素出现的次数。
  2. 遍历数组 B 匹配:遍历数组 B,对于每个元素,在哈希表中查找其出现次数并累加。

代码实现

const readline = require('readline');const rl = readline.createInterface({input: process.stdin,output: process.stdout,terminal: false
});// 输入处理逻辑
let lineCount = 0;
let M, N, A, B;rl.on('line', (line) => {switch (lineCount) {case 0: // 读取数组A的长度MM = parseInt(line.trim());break;case 1: // 读取数组B的长度NN = parseInt(line.trim());break;case 2: // 读取数组A的元素A = line.trim().split(/\s+/).map(Number);if (A.length !== M) {console.log(0);process.exit();}break;case 3: // 读取数组B的元素B = line.trim().split(/\s+/).map(Number);if (B.length !== N) {console.log(0);process.exit();}processInput(); // 处理输入数据break;}lineCount++;
});function processInput() {// 统计A中元素的频率const countMap = {};for (const num of A) {countMap[num] = (countMap[num] || 0) + 1;}// 计算总匹配次数let total = 0;for (const num of B) {total += countMap[num] || 0;}console.log(total);rl.close();
}

代码详细解析

  1. 输入处理

    const rl = readline.createInterface(...) // 创建输入接口
    rl.on('line', ...)                       // 监听每一行输入
    
    • 使用 Node.js 的 readline 模块逐行读取输入
    • 通过 switch 语句处理不同行的输入内容
  2. 数组验证

    if (A.length !== M) { ... } // 验证数组A长度
    if (B.length !== N) { ... } // 验证数组B长度
    
    • 检查输入数组长度是否与声明的长度一致
    • 发现不一致立即输出 0 并退出
  3. 哈希表统计

    const countMap = {};
    for (const num of A) {countMap[num] = (countMap[num] || 0) + 1;
    }
    
    • 使用普通对象作为哈希表
    • (countMap[num] || 0) 实现类似 Python 的 get() 方法
  4. 匹配计算

    for (const num of B) {total += countMap[num] || 0;
    }
    
    • 遍历数组 B 的每个元素
    • 累加哈希表中对应元素的出现次数

示例测试

示例1输入

5
4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • A 中每个元素出现1次
  • B 中的 4、3、2、1 均能在 A 中找到
  • 总匹配次数 = 1+1+1+1 = 4

示例2输入

6
3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • A 中 1 出现2次,2 出现2次
  • B 中的 1 匹配2次,2 匹配2次
  • 总匹配次数 = 2+2+0 = 4

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次
    • 匹配计算:O(N),遍历数组B一次
    • 总复杂度:O(M + N),线性时间复杂度
  2. 空间复杂度

    • 哈希表存储:最差 O(M)(所有元素不同时)
    • 输入存储:O(M + N) 存储两个数组
  3. 性能优势

    • 相比暴力法 O(M*N) 的复杂度,效率提升数百倍
    • 例如当 M=N=10^5 时,暴力法需要 1e10 次运算(不可行),而哈希法仅需 2e5 次
  4. JavaScript 特性利用

    • 对象动态属性实现哈希表
    • || 运算符实现默认值
    • map(Number) 快速类型转换
  5. 扩展性

    • 支持非数字类型(需可哈希)
    • 可轻松修改为统计三元组等复杂场景
    • 适用于浏览器和 Node.js 双环境

C++

问题分析

给定两个数组A和B,统计满足A[i] == B[j]的二元组(i,j)的总个数。直接遍历所有组合的时间复杂度为O(M*N),但通过哈希表优化可以将时间复杂度降低到O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组A,用unordered_map记录每个元素出现的次数。
  2. 遍历数组B匹配:遍历数组B,对于每个元素,在哈希表中查找其出现次数并累加。

代码实现

#include <iostream>
#include <vector>
#include <sstream>
#include <unordered_map>using namespace std;int main() {int M, N;// 读取数组A和B的长度cin >> M >> N;// 清除输入缓冲区中的换行符cin.ignore(numeric_limits<streamsize>::max(), '\n');// 读取数组A的元素string lineA;getline(cin, lineA);vector<int> A;stringstream ssA(lineA);int num;while (ssA >> num) {A.push_back(num);}// 验证数组A长度if (A.size() != M) {cout << 0 << endl;return 0;}// 读取数组B的元素string lineB;getline(cin, lineB);vector<int> B;stringstream ssB(lineB);while (ssB >> num) {B.push_back(num);}// 验证数组B长度if (B.size() != N) {cout << 0 << endl;return 0;}// 统计数组A中每个元素的出现次数unordered_map<int, int> countMap;for (int num : A) {countMap[num]++;}// 遍历数组B统计总匹配次数int total = 0;for (int num : B) {total += countMap[num]; // 若不存在则返回0}cout << total << endl;return 0;
}

代码逐行解析

  1. 输入处理

    cin >> M >> N;  // 读取数组A和B的长度
    cin.ignore(...); // 清除缓冲区中的换行符
    getline(cin, lineA); // 读取数组A的元素行
    
    • 使用cin读取数组长度后,必须用cin.ignore()清除缓冲区残留的换行符
    • getline按行读取数组元素,避免空格和换行符干扰
  2. 数组元素解析

    stringstream ssA(lineA); // 将字符串转换为流
    while (ssA >> num) { ... } // 逐个读取整数
    
    • stringstream将字符串按空格分割为整数流
    • vector动态存储数组元素
  3. 哈希表统计

    unordered_map<int, int> countMap;
    for (int num : A) { countMap[num]++; }
    
    • unordered_map以O(1)时间复杂度实现键值查找
    • 遍历数组A时,每个元素在哈希表中计数+1
  4. 匹配次数计算

    total += countMap[num]; // 若不存在则返回0
    
    • 直接通过countMap[num]访问次数,未找到时返回0
    • 遍历数组B时累加所有匹配次数

示例测试

示例1输入

5 4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • A中的每个元素出现1次
  • B中的4、3、2、1均能在A中找到,总匹配次数=1+1+1+1=4

示例2输入

6 3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • A中1出现2次,2出现2次
  • B中的1匹配2次,2匹配2次,3匹配0次
  • 总匹配次数=2+2+0=4

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次
    • 匹配计算:O(N),遍历数组B一次
    • 总复杂度:O(M + N),线性时间复杂度
  2. 空间复杂度

    • 哈希表存储:最差O(M)(所有元素不同时)
    • 输入存储:O(M + N) 存储两个数组
  3. 性能优势

    • 相比暴力法的O(M*N),效率提升数百倍
    • 例如当M=N=10^5时,暴力法需要1e10次运算(不可行),哈希法仅需2e5次
  4. C++特性利用

    • unordered_map实现哈希表,平均O(1)查询时间
    • stringstream处理复杂的输入分割逻辑
    • vector动态数组自动管理内存
  5. 扩展性

    • 支持非整型数据(需自定义哈希函数)
    • 可轻松修改为统计三元组等复杂场景
    • 适用于高性能计算场景(如嵌入式系统)

C语言

问题分析

我们需要统计两个数组A和B中满足A[i] == B[j]的二元组(i,j)的总个数。直接遍历所有组合的时间复杂度为O(M*N),但通过哈希表优化可以将时间复杂度降低到O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组A,使用哈希表记录每个元素出现的次数。
  2. 遍历数组B匹配:遍历数组B,对于每个元素,在哈希表中查找其出现次数并累加。

代码实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>#define HASH_SIZE 10007 // 哈希表大小,质数减少冲突typedef struct HashNode {int key;           // 存储元素值int value;         // 存储出现次数struct HashNode *next;
} HashNode;typedef struct {HashNode **buckets; // 哈希桶数组int size;           // 哈希表大小
} HashMap;// 创建哈希表
HashMap* createHashMap(int size) {HashMap *map = (HashMap*)malloc(sizeof(HashMap));map->size = size;map->buckets = (HashNode**)calloc(size, sizeof(HashNode*)); // 初始化为空指针return map;
}// 插入元素到哈希表
void put(HashMap *map, int key) {int index = abs(key) % map->size; // 哈希函数:绝对值取模处理负数HashNode *current = map->buckets[index];// 遍历链表,查找是否已存在该键while (current != NULL) {if (current->key == key) {current->value++; // 存在则计数加1return;}current = current->next;}// 创建新节点插入链表头部HashNode *newNode = (HashNode*)malloc(sizeof(HashNode));newNode->key = key;newNode->value = 1;newNode->next = map->buckets[index];map->buckets[index] = newNode;
}// 查询元素出现次数
int get(HashMap *map, int key) {int index = abs(key) % map->size;HashNode *current = map->buckets[index];// 遍历链表查找键while (current != NULL) {if (current->key == key) {return current->value;}current = current->next;}return 0; // 未找到返回0
}// 释放哈希表内存
void freeHashMap(HashMap *map) {for (int i = 0; i < map->size; i++) {HashNode *current = map->buckets[i];while (current != NULL) {HashNode *temp = current;current = current->next;free(temp);}}free(map->buckets);free(map);
}int main() {char line[1000000];int M, N;// 读取数组A和B的长度fgets(line, sizeof(line), stdin);sscanf(line, "%d", &M);fgets(line, sizeof(line), stdin);sscanf(line, "%d", &N);// 读取数组A的元素fgets(line, sizeof(line), stdin);int *A = (int*)malloc(M * sizeof(int));int count = 0;char *token = strtok(line, " ");while (token != NULL && count < M) {A[count++] = atoi(token);token = strtok(NULL, " ");}if (count != M) { // 验证元素数量是否正确printf("0\n");free(A);return 0;}// 读取数组B的元素fgets(line, sizeof(line), stdin);int *B = (int*)malloc(N * sizeof(int));count = 0;token = strtok(line, " ");while (token != NULL && count < N) {B[count++] = atoi(token);token = strtok(NULL, " ");}if (count != N) { // 验证元素数量是否正确printf("0\n");free(A);free(B);return 0;}// 创建哈希表并统计A的频次HashMap *map = createHashMap(HASH_SIZE);for (int i = 0; i < M; i++) {put(map, A[i]);}// 遍历B数组累加匹配次数int total = 0;for (int i = 0; i < N; i++) {total += get(map, B[i]);}printf("%d\n", total);// 释放内存freeHashMap(map);free(A);free(B);return 0;
}

代码详细解析

  1. 哈希表结构定义

    • HashNode:链表节点,存储键、值和下一个节点的指针。
    • HashMap:哈希表结构,包含桶数组和大小。
  2. 哈希表操作

    • createHashMap:分配内存,初始化桶数组。
    • put:插入元素。若键存在,计数加1;否则新建节点插入链表头部。
    • get:查询键的出现次数,遍历链表查找。
    • freeHashMap:释放哈希表所有节点内存。
  3. 输入处理

    • 使用fgets逐行读取输入,strtok分割字符串。
    • 验证数组长度是否与输入一致,避免数据错误。
  4. 核心逻辑

    • 遍历数组A,通过哈希表统计频次。
    • 遍历数组B,累加哈希表中的频次,得到总匹配数。

示例测试

示例1输入

5
4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • A中每个元素出现1次。
  • B中4、3、2、1各匹配1次,总对数4。

示例2输入

6
3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • A中1出现2次,2出现2次。
  • B中1和2各匹配2次,总对数4。

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次。
    • 匹配计算:O(N),遍历数组B一次。
    • 总复杂度:O(M + N),线性时间复杂度。
  2. 空间复杂度

    • 哈希表:O(M),存储数组A元素的频次。
    • 输入数组:O(M + N),存储原始数据。
  3. 优势

    • 高效性:避免暴力法的O(M*N)复杂度。
    • 通用性:支持任意整数(包括负数),哈希函数处理简单。
  4. 适用场景

    • 大规模数据,如M和N达到10^5级别。
    • 需要快速统计元素频次并匹配的场景。

GO

问题分析

给定两个数组A和B,统计满足A[i] == B[j]的二元组(i,j)的总个数。直接遍历所有组合的时间复杂度为O(M*N),但通过哈希表优化可以将时间复杂度降低到O(M + N)。


解题思路

  1. 哈希表统计频率:遍历数组A,用map记录每个元素出现的次数。
  2. 遍历数组B匹配:遍历数组B,对于每个元素,在哈希表中查找其出现次数并累加。

代码实现

package mainimport ("bufio""fmt""os""strconv""strings"
)func main() {// 创建输入扫描器scanner := bufio.NewScanner(os.Stdin)// 读取数组A的长度Mscanner.Scan()M, _ := strconv.Atoi(scanner.Text())// 读取数组B的长度Nscanner.Scan()N, _ := strconv.Atoi(scanner.Text())// 读取数组A的元素scanner.Scan()aLine := scanner.Text()A := strings.Fields(aLine)if len(A) != M {fmt.Println(0)return}// 读取数组B的元素scanner.Scan()bLine := scanner.Text()B := strings.Fields(bLine)if len(B) != N {fmt.Println(0)return}// 统计数组A中元素的出现次数countMap := make(map[string]int)for _, numStr := range A {countMap[numStr]++}// 计算总匹配次数total := 0for _, numStr := range B {total += countMap[numStr]}fmt.Println(total)
}

代码详细解析

  1. 输入处理

    • bufio.Scanner:创建输入扫描器逐行读取数据。
    • strconv.Atoi:将字符串转换为整数,用于读取数组长度。
    • strings.Fields:按空格分割字符串,处理数组元素。
  2. 数组验证

    if len(A) != M { ... }  // 验证数组A长度
    if len(B) != N { ... }  // 验证数组B长度
    
    • 检查分割后的元素数量是否与声明的长度一致。
  3. 哈希表统计

    countMap := make(map[string]int)
    for _, numStr := range A {countMap[numStr]++
    }
    
    • 使用字符串直接作为键(避免类型转换开销)。
    • 遍历数组A时,每个字符串元素计数+1。
  4. 匹配计算

    for _, numStr := range B {total += countMap[numStr]
    }
    
    • 遍历数组B的每个元素,累加哈希表中的出现次数。
    • 未找到时返回默认值0。

示例测试

示例1输入

5
4
1 2 3 4 5
4 3 2 1

输出

4

解析

  • A中每个元素出现1次。
  • B中的"4""3""2""1"均匹配1次,总对数4。

示例2输入

6
3
1 2 4 4 2 1
1 2 3

输出

4

解析

  • A中"1"出现2次,"2"出现2次。
  • B中的"1"匹配2次,"2"匹配2次,总对数4。

综合分析

  1. 时间复杂度

    • 统计频率:O(M),遍历数组A一次。
    • 匹配计算:O(N),遍历数组B一次。
    • 总复杂度:O(M + N),线性时间复杂度。
  2. 空间复杂度

    • 哈希表存储:O(M),存储数组A元素的字符串形式。
    • 输入存储:O(M + N),存储原始字符串数据。
  3. 性能优化

    • 直接使用字符串键:避免多次类型转换。
    • 哈希表快速查找:Go的map实现基于哈希表,平均O(1)查询时间。
  4. 适用场景

    • 适用于大规模数据(如M=1e6, N=1e6)。
    • 需要快速统计元素出现次数的场景。
    • 元素包含非数字字符的场景(如"apple")。
  5. 扩展性

    • 支持任意可哈希类型(如结构体)。
    • 可轻松修改为统计三元组、四元组等。

更多内容:

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

本文发表于【纪元A梦】,关注我,获取更多实用教程/资源!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/901746.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

半导体制造如何数字化转型

半导体制造的数字化转型正通过技术融合与流程重构&#xff0c;推动着这个精密产业的全面革新。全球芯片短缺与工艺复杂度指数级增长的双重压力下&#xff0c;头部企业已构建起四大转型支柱&#xff1a; 1. 数据中枢重构产线生态 台积电的「智慧工厂4.0」部署着30万物联网传感器…

[Spark]深入解密Spark SQL源码:Catalyst框架如何优雅地解析你的SQL

本文内容组织形式 总结具体例子执行语句解析层优化层物理计划层执行层 猜你喜欢PS 总结 先写个总结&#xff0c;接下来会分别产出各个部分的源码解析&#xff0c;Spark SQL主要分为以下五个执行部分。 具体例子 接下来举个具体的例子来说明 执行语句 SELECT name, age FR…

【数据结构】4.单链表实现通讯录

在上一篇文章我们学会了用单链表来实现各种方法&#xff0c;在这一篇文章我们将在单链表的基础上实现通讯录。 0、准备工作 实现通讯录之前&#xff0c;我们还需要在单链表的基础上添加2个文件&#xff0c;头文件Contact.h和源文件Contact.c。Contact.c来实现通讯录方法的声明…

【bash】.bashrc

查看当前路径文件数量 alias file_num"ls -l | grep ^- | wc -l"查看文件大小 alias file_size"du -sh"alias ll alias ll"ls -ltrh"cd的同时执行ll alias cdcdls; function cdls() {builtin cd "$1" && ll }自定义prompt…

微信小程序实战案例 - 餐馆点餐系统 阶段 2 – 购物车

阶段 2 – 购物车&#xff08;超详细版&#xff09; 目标 把“加入购物车”做成 全局状态&#xff0c;任何页面都能读写在本地 持久化&#xff08;关闭小程序后购物车仍在&#xff09;新建 购物车页&#xff1a;数量增减、总价实时计算、去结算入口打 Git Tag v2.0‑cart 1. …

从红黑树到哈希表:原理对比与典型场景应用解析(分布式以及布隆过滤器)

在数据结构的世界里&#xff0c;红黑树一直以「自平衡二叉查找树」的身份备受赞誉。凭借红黑节点的精妙设计&#xff0c;它能将插入、删除、查找的时间复杂度稳定控制在 ( log ⁡ n ) (\log n) (logn)&#xff0c;成为处理有序数据的经典方案。然而&#xff0c;当业务场景对「…

游戏报错?MFC140.dll怎么安装才能解决问题?提供多种MFC140.dll丢失修复方案

MFC140.dll 是 Microsoft Visual C 2015 运行库的重要组成部分&#xff0c;许多软件和游戏依赖它才能正常运行。如果你的电脑提示 "MFC140.dll 丢失" 或 "MFC140.dll 未找到"&#xff0c;说明系统缺少该文件&#xff0c;导致程序无法启动。本文将详细介绍 …

《电子类专业:通往科技未来的钥匙》

一、电子类专业全景概览 在当今科技飞速发展的时代,电子类专业无疑占据着现代科技体系中基础与核心的重要地位。从我们日常生活中不可或缺的智能手机、电脑,到推动社会进步的人工智能、大数据技术,再到探索宇宙奥秘的航天航空设备,电子类专业的身影无处不在。它就像一把万…

Java--批量删除

前端部分 前端代码主要负责收集用户选择的学生记录的 id&#xff0c;并将这些 id 发送给后端的 DeleteMoreServlet 进行处理。 批量删除按钮绑定点击事件 $(".deleteMore").on("click",function(){// ... }); 当用户点击 “批量删除” 按钮时&#xff…

2025年4月份生活有感

今天在5000B培训的下午&#xff0c;一起入所来的小伙伴&#xff0c;有个申请了深圳大学的博士&#xff0c;已录取。哎&#xff0c;想起了当年申博时候信心和决心不足&#xff0c;导致后面匆匆的拿了offer去工作。看到同事的选择还是非常羡慕&#xff0c;想到自己5月份的婚礼&am…

数学建模学习资料免费分享:历年赛题与优秀论文、算法课程、数学软件等

本文介绍并分享自己当初准备数学建模比赛时&#xff0c;收集的所有资料&#xff0c;包括历年赛题与论文、排版模板、算法讲解课程与书籍、评分标准、数学建模软件等各类资料。 最近&#xff0c;准备将自己在学习过程中&#xff0c;到处收集到的各类资料都整理一下&#xff0c;并…

关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格

以下是关于 微服务负载均衡 的详细说明&#xff0c;涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格&#xff1a; 1. 负载均衡的核心概念 负载均衡在微服务中用于将请求分发到多个服务实例&#xff0c;以实现&#xff1a; 高可用性&#xff1a;避免单点故障。性…

个人博客搭建过程

尝试博客搭建,前面注册部分很简单&#xff0c;就不写了&#xff0c;以我看到的一个博客为基础&#xff0c;加上我自己的测试结束 1.官网 https://dash.infinityfree.com 前半部分参考&#xff1a; 使用Infinityfree免费虚拟主机搭建一个wordpress网站 2.创建账户或登录您的…

Proxmox VE 网络配置命令大全

如果对 Proxmox VE 全栈管理感兴趣&#xff0c;可以关注“Proxmox VE 全栈管理”专栏&#xff0c;后续文章将围绕该体系&#xff0c;从多个维度深入展开。 概要&#xff1a;Proxmox VE 网络配置灵活&#xff0c;满足虚拟化组网需求。基础靠桥接实现虚拟机与物理网络互联&#x…

【QT入门到晋级】QT打动态库包及引入动态库包

前言 本篇为持续更新状态&#xff0c;内容包含window、Linux下打动态库包&#xff0c;以及引入动态库包的方式。 一、window 1、动态库打包 以百度的OCR接口调用打dll库为例&#xff0c;以下为qtcreator创建动态库过程&#xff1a; 1.1Qtcreator创建lib项目 创建成功后&…

Uniapp: 大纲

目录 一、基础巩固1.1、Uniapp:下拉选择框ba-tree-picker1.2、Uniapp&#xff1a;确认框1.3、Uniapp&#xff1a;消息提示框1.4、Uniapp&#xff1a;列表提示框1.5、Uniapp&#xff1a;获取当前定位坐标 二、项目配置2.1、Uniapp&#xff1a;修改端口号2.2、Uniapp&#xff1a;…

WPF 从Main()方法启动

1.去掉App.xaml StartupUri“MainWindow.xaml” 只会让App.g.cs 不生成这行代码&#xff0c;但是还是会生成的App.g.cs文件中生成Main方法 this.StartupUri new System.Uri("MainWindow.xaml", System.UriKind.Relative);默认的App.xaml的生成操作是 应用程序定义…

ADB的安装及抓取日志(2)

三、ADB抓取日志 在使用ADB抓取日志前&#xff0c;首先要保证电脑已经安装并配置ADB&#xff0c;在上一节已经验证完成。连接设备&#xff1a;可通过USB或者WI-FI&#xff0c;将安卓设备与电脑连接&#xff0c;并启用USB调试模式&#xff0c;此处我选择的是通过电脑与安卓设备…

opencv 灰度实验

opencv 灰度实验 1. 最大值法2. 平均值法3. 加权均值法4(直接读取灰度图)cv2.IMREAD_GRAYSCALE5内置将原图转换为灰度图cv2.cvtColor()6 两个极端的灰度值 灰度图与彩色图最大的不同就是&#xff1a;彩色图是由R、G、B三个通道组成&#xff0c;而灰度图只有一个通道&#xff0c…

『Kubernetes(K8S) 入门进阶实战』实战入门 - Pod 详解

『Kubernetes(K8S) 入门进阶实战』实战入门 - Pod 详解 Pod 结构 每个 Pod 中都可以包含一个或者多个容器&#xff0c;这些容器可以分为两类 用户程序所在的容器&#xff0c;数量可多可少Pause 容器&#xff0c;这是每个 Pod 都会有的一个根容器&#xff0c;它的作用有两个 可…