legongju.com
我们一直在努力
2025-01-10 10:06 | 星期五

如何在C++中高效地操作table

在C++中,可以使用多种数据结构来高效地操作表格,例如std::vectorstd::arraystd::map

  1. 使用std::vectorstd::array

对于已知大小的表格,可以使用std::vectorstd::array。这两者都是连续内存分配的容器,因此访问元素非常快。如果需要动态调整大小,可以使用std::vector;否则,可以使用std::array

#include
#include
#include

int main() {
    // 使用 std::vector
    std::vector> table_vec(3, std::vector(4));
    table_vec[0][0] = 1;
    table_vec[1][2] = 2;

    // 使用 std::array
    std::array, 3> table_arr;
    table_arr[0][0] = 1;
    table_arr[1][2] = 2;

    return 0;
}
  1. 使用std::mapstd::unordered_map

对于不规则的表格或者需要根据键值对进行查找的情况,可以使用std::mapstd::unordered_mapstd::map内部使用红黑树实现,查找时间复杂度为O(log n);std::unordered_map内部使用哈希表实现,查找时间复杂度为O(1)。

#include
#include 
#include 

int main() {
    // 使用 std::map
    std::map, int> table_map;
    table_map[{0, 0}] = 1;
    table_map[{1, 2}] = 2;

    // 使用 std::unordered_map
    std::unordered_map, int> table_unordered_map;
    table_unordered_map[{0, 0}] = 1;
    table_unordered_map[{1, 2}] = 2;

    return 0;
}
  1. 自定义数据结构:

如果需要更高的性能或特定的功能,可以考虑设计自己的数据结构。例如,可以实现一个稀疏矩阵类,只存储非零元素。

#include
#include
#include 

class SparseMatrix {
public:
    void set(int row, int col, int value) {
        if (value =https://www.yisu.com/ask/= 0) {"hljs">int get(int row, int col) const {
        auto it = data.find({row, col});
        if (it != data.end()) {
            return it->second;
        }
        return 0;
    }

private:
    std::unordered_map, int> data;
};

int main() {
    SparseMatrix matrix;
    matrix.set(0, 0, 1);
    matrix.set(1, 2, 2);

    std::cout<< matrix.get(0, 0)<< std::endl; // 输出 1
    std::cout<< matrix.get(1, 2)<< std::endl; // 输出 2

    return 0;
}

选择合适的数据结构取决于你的具体需求和性能要求。在实际应用中,可能需要根据实际情况进行测试和调整。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/98314.html

相关推荐

  • C++线程池库如何实现任务的分配

    C++线程池库如何实现任务的分配

    在C++中,实现一个线程池库主要包括以下几个步骤: 定义任务类型:首先需要定义一个可调用对象类型,例如std::function,用于表示任务。 创建线程池:创建一个固...

  • C++线程池库的线程复用是如何实现的

    C++线程池库的线程复用是如何实现的

    C++线程池库的线程复用主要通过以下几个步骤实现: 创建线程池:首先,需要创建一个线程池对象,该对象负责管理和调度线程。线程池在创建时会根据指定的线程数量...

  • 如何在C++中使用strftime输出日期和时间

    如何在C++中使用strftime输出日期和时间

    strftime 是 C++ 标准库中的一个函数,用于将日期和时间格式化为字符串。以下是如何在 C++ 中使用 strftime 输出日期和时间的示例:
    #include
    #includ...

  • 如何在C++中使用strftime格式化时间

    如何在C++中使用strftime格式化时间

    strftime 是 C++ 标准库中的一个函数,用于将 tm 结构体(包含日期和时间信息)格式化为字符串。以下是如何在 C++ 中使用 strftime 的示例:
    #include

  • C++ table的数据结构有哪些选择

    C++ table的数据结构有哪些选择

    在C++中,表(Table)是一种用于存储和组织数据的数据结构 二维数组(2D Array):这是最基本的表数据结构。它是一个固定大小的、连续的内存块,可以通过行和列的...

  • C++ option类型的内存管理

    C++ option类型的内存管理

    在 C++ 中,std::optional 是一个模板类,用于表示一个值可能存在也可能不存在。它是 C++17 引入的一种新特性,主要用于解决“空指针”或“异常”等问题。std::o...

  • 如何自定义C++的option类

    如何自定义C++的option类

    在 C++ 中,创建一个自定义的 Option 类可以让你更灵活地处理可选值(例如,值可能存在,也可能不存在)
    #include
    #include template
    class Opti...

  • option类型在C++中的最佳实践

    option类型在C++中的最佳实践

    在 C++ 中,std::optional 是一个模板类,用于表示可能存在或缺失的值 避免使用裸指针:当你需要返回一个可能为空的值时,不要使用裸指针。相反,应该使用 std::...