大数据的left_join

刷算法题:

第一遍:1.看5分钟,没思路看题解

2.通过题解改进自己的解法,并且要写每行的注释以及自己的思路。

3.思考自己做到了题解的哪一步,下次怎么才能做对(总结方法)

4.整理到自己的自媒体平台。

5.再刷重复的类似的题目,根据时间和任务安排刷哪几个板块

6.用c++语言 都刷过一遍了 就刷中等

一.题目

用c++写一个函数,内存有限,给了两个表格,怎么实现left join?(滑动窗口法)两个表都无法直接加载到内存里 ,并且给出两个二维vector代表文件即可

二、反思

1.自己的解法

cpp 复制代码
#include <iostream>
#include <vector>
#include <unordered_map>
#include <string>

// 定义一行数据类型
using Row = std::vector<std::string>;

// 滑动窗口方式实现 LEFT JOIN
std::vector<Row> leftJoin(const std::vector<Row>& table1, const std::vector<Row>& table2, size_t joinCol1, size_t joinCol2, size_t chunkSize) {
    std::vector<Row> result; // 存储最终的结果

    size_t table1Size = table1.size();
    size_t table2Size = table2.size();

    for (size_t i = 0; i < table1Size; i += chunkSize) {
        size_t end = std::min(i + chunkSize, table1Size);

        // 将当前窗口的数据加载到内存中
        std::vector<Row> table1Chunk(table1.begin() + i, table1.begin() + end);

        // 构建右表的哈希索引
        std::unordered_multimap<std::string, Row> table2Map;
        for (const auto& row : table2) {
            if (joinCol2 < row.size()) {
                table2Map.emplace(row[joinCol2], row);
            }
        }

        // 对当前窗口的左表进行匹配
        for (const auto& row1 : table1Chunk) {
            bool matched = false;

            if (joinCol1 < row1.size()) {
                auto range = table2Map.equal_range(row1[joinCol1]);

                for (auto it = range.first; it != range.second; ++it) {
                    Row joinedRow = row1; // 复制左表当前行
                    joinedRow.insert(joinedRow.end(), it->second.begin(), it->second.end());
                    result.push_back(joinedRow);
                    matched = true;
                }
            }

            // 如果没有匹配项,则补空
            if (!matched) {
                Row joinedRow = row1;
                joinedRow.resize(row1.size() + table2[0].size(), "NULL");
                result.push_back(joinedRow);
            }
        }
    }

    return result;
}

int main() {
    // 示例表格1(左表)
    std::vector<Row> table1 = {
        {"1", "Alice"},
        {"2", "Bob"},
        {"3", "Charlie"}
    };

    // 示例表格2(右表)
    std::vector<Row> table2 = {
        {"1", "New York"},
        {"2", "Los Angeles"}
    };

    // 左表的连接列和右表的连接列索引
    size_t joinCol1 = 0;
    size_t joinCol2 = 0;

    // 设置块大小
    size_t chunkSize = 2;

    // 执行 LEFT JOIN
    auto result = leftJoin(table1, table2, joinCol1, joinCol2, chunkSize);

    // 输出结果
    for (const auto& row : result) {
        for (const auto& col : row) {
            std::cout << col << "\t";
        }
        std::cout << "\n";
    }

    return 0;
}

2.题目的解法

cpp 复制代码
2

3.思路的异同

三.进步的地方

面试的时候遇到的,根本做不出来,忘记multimap这个数据结构了。

相关推荐
qq_433554543 分钟前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
努力学习编程的伍大侠8 分钟前
基础排序算法
数据结构·c++·算法
XiaoLeisj35 分钟前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
yuyanjingtao1 小时前
CCF-GESP 等级考试 2023年9月认证C++四级真题解析
c++·青少年编程·gesp·csp-j/s·编程等级考试
Jasmine_llq1 小时前
《 火星人 》
算法·青少年编程·c#
闻缺陷则喜何志丹1 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
charlie1145141911 小时前
C++ STL CookBook
开发语言·c++·stl·c++20
Lenyiin1 小时前
01.02、判定是否互为字符重排
算法·leetcode
小林熬夜学编程1 小时前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http