RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 841309
Accepted
Никита Самоуков
Никита Самоуков
Asked:2020-06-13 06:59:00 +0000 UTC2020-06-13 06:59:00 +0000 UTC 2020-06-13 06:59:00 +0000 UTC

带间隙的 3D 数组(C++,地图)

  • 772

我有一个带有此声明的 3D 数组:

unordered_map<int, unordered_map<int, unordered_map<int, T*>>> &ll=data[0];

如何创建、删除、检查其中的存在、遍历整个阵列?我知道几种方法,但它们有 100 行长而且效率很低。

c++
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    AnT stands with Russia
    2020-06-13T07:36:07Z2020-06-13T07:36:07Z
    • 通过索引创建和/或分配元素[i][j][k]很容易:通过运算符的简单调用[]将为您创建所有内容

      ll[i][j][k] = /* какое-то значение вашего типа `T *` */;
      
    • 通过索引检查是否存在[i][j][k]也很容易,但更麻烦:

      if (auto iti = ll.find(i); iti != ll.end())
        if (auto itj = iti->second.find(j); itj != iti->second.end())
          if (auto itk = itj->second.find(k); itk != itj->second.end())
            /* Нашлось! Значение равно `itk->second` */;
      
    • 也很容易通过:

      for (const auto &pi : ll)
        for (const auto &pj : pi.second)
          for (const auto &pk : pj.second)
            /* Элемент `pk.second` с индексами [pi.first][pj.first][pk.first] */;
      
    • 按索引删除[i][j][k]:取决于您想删除当前不需要的所有内容的热情程度,即 空子图。删除所有内容的最激进方法,检查被删除元素是否存在:

      if (auto iti = ll.find(i); iti != ll.end())
        if (auto itj = iti->second.find(j); itj != iti->second.end())
          if (auto itk = itj->second.find(k); itk != itj->second.end())
          {
            /* Удаляем, если нужно, сам `T`, т.е. `itk->second` */
      
            itj->second.erase(itk);
            if (itj->second.empty())
            {
              iti->second.erase(itj);
              if (iti->second.empty())
                ll.erase(iti);
            }
          }
      

      如果您绝对确定该元素存在[i][j][k],您的T不需要删除,并且您不想处理空子图的早期删除,那么一切都可以在一行中完成

      ll.find(i)->second.find(j)->second.erase(k);
      

    unordered_map但是,有可能您最好使用常规的“一层”而不是这样的“三层” unordered_map,其中三个数字(i, j, k)( std::tuple) 将作为键。它会让很多事情变得更容易。

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5