Аватар для SaynorPRO
11 / 11 / 5
Регистрация: 05.10.2016
Сообщений: 122

Трёхмерный вектор занимает в четыре раза больше памяти, чем должен

09.06.2017, 11:13. Показов 1508. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создаю трёхмерный вектор таким способом
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
vector<vector<vector<int> > > dp;
int n, k;
 
void initializeVector () {
  dp.resize(n + 2);
  for (int i = 1; i <= n; i++) {
    dp[i].resize(n + 2);
  }
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= n; j++) {
      dp[i][j].resize(k, 0);
    }
  }
}
 
int main() {
  cin >> n >> k;
  initializeVector();
  return 0;
}
По расчётам он должен занимать (102 * 102 * 2000) / (1024)^2 = ~20 мб, а на самом деле он ест под 80 мб. Почему так?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.06.2017, 11:13
Ответы с готовыми решениями:

Почему строка в 2 раза длиннее, а памяти занимает только в 1.5 раз больше?
public class App { public static void main(String args) throws Exception { ...

Dev C ++ занимает больше памяти чем турбо си
Почему на dev C ++ занимает больше памяти чем турбо си? или однаково? 64 розрядна на dev c++

Первая бригада производит в четыре раза больше продукции, чем вторая
Первая бригада производит в четыре раза больше продукции, чем вторая. Вероятность того, что производимая продукция окажется стандартной...

9
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
09.06.2017, 11:25
Лучший ответ Сообщение было отмечено SaynorPRO как решение

Решение

SaynorPRO, надо понять и простить.
C++
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
#include <vector>
 
int main()
{
    std::vector<int> v(100);
    v.resize(42);
    std::cout << v.capacity() << std::endl;
    v.resize(1);
    std::cout << v.capacity() << std::endl;
}
1
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
09.06.2017, 11:27
Цитата Сообщение от SaynorPRO Посмотреть сообщение
Почему так?
Эт что, строчка из диспетчера задач?
А программе ничего кроме вектора не надо, да? )))
0
 Аватар для SaynorPRO
11 / 11 / 5
Регистрация: 05.10.2016
Сообщений: 122
09.06.2017, 11:29  [ТС]
MrGluck, получается без shrink_to_fit не обойтись? А до 11 версии так вообще нельзя никак капасити уменьшить?

Добавлено через 59 секунд
Croessmah, и что же ей может быть надо на лишних 60 мегабайт?
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
09.06.2017, 11:34
Цитата Сообщение от SaynorPRO Посмотреть сообщение
А до 11 версии так вообще нельзя никак капасити уменьшить?
C++
1
std::vector<Type>(vec).swap(vec);
Цитата Сообщение от SaynorPRO Посмотреть сообщение
и что же ей может быть надо на лишних 60 мегабайт?
Откуда мы знаем что там у Вас?
И диспетчер задач не лучший показатель.
К тому же сколько памяти реально выделяется
при запросе, зависит от устройства ОС.
Например, запросили мы один байт, программе дали один байт,
и обращается она с ним как с одним байтом,
а на самом деле система отдала нам целую страницу.
1
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
09.06.2017, 11:37
C++
1
2
3
4
5
6
7
#include <vector>
 
int main()
{
    const int n = 102, k = 2000;
    std::vector<std::vector<std::vector<int> > > dp(n, std::vector<std::vector<int> >(n, std::vector<int>(k)));
}
1
 Аватар для SaynorPRO
11 / 11 / 5
Регистрация: 05.10.2016
Сообщений: 122
09.06.2017, 11:45  [ТС]
Croessmah,
Цитата Сообщение от Croessmah Посмотреть сообщение
std::vector<Type>(vec).swap(vec);
Не очень понятна эта строчка. Не могли бы вы объяснить?
Цитата Сообщение от Croessmah Посмотреть сообщение
Откуда мы знаем что там у Вас?
Ничего больше нет. Эта вся программа.

Добавлено через 4 минуты
MrGluck, Точно, а я ещё так пытался инициализировать и подумал ещё, что c++ не умеет трёхмерные векторы конструировать.
C++
1
vector<vector<vector<int> > > dp(n, vector<int>(n, vector<int>(k, 0)));
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
09.06.2017, 11:53
Цитата Сообщение от SaynorPRO Посмотреть сообщение
что c++ не умеет трёхмерные векторы конструировать.
Вектору всё равно что внутри хранить - хоть ещё один вектор.

Добавлено через 2 минуты
Цитата Сообщение от SaynorPRO Посмотреть сообщение
Не очень понятна эта строчка. Не могли бы вы объяснить?
Создать временный вектор нужного размера и поменять местами с текущим вектором. В итоге текущий вектор приобретает указанный нами размер, а "бывший текущий" уничтожается.
0
 Аватар для SaynorPRO
11 / 11 / 5
Регистрация: 05.10.2016
Сообщений: 122
09.06.2017, 12:17  [ТС]
MrGluck, а зачем свапать? vector<Type>(vec) означает, что, грубо говоря, будет создана точная копия вектора vec. Как смысл тогда свапать два одинаковых вектора?
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
09.06.2017, 12:18
Цитата Сообщение от SaynorPRO Посмотреть сообщение
будет создана точная копия вектора vec
только с необходимым размером, без запаса.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.06.2017, 12:18
Помогаю со студенческими работами здесь

Оперативной памяти в два раза больше, чем установлено
Оперативной памяти в два раза больше,чем установлено. Из за чего такая вещь может возникнуть? материнская плата: ASUS M5A78L-M/USB3 ...

Операция занимает больше времени, чем ожидалось
При компиляции и запуске проекта появляется следующее окно &quot;64- разрядная операция занимает больше времени, чем ожидалось. Это может быть...

Webbrowser при обновлении страницы занимает больше оперативной памяти
Имеется форма VCL, на ней кнопка и браузер, после каждого просмотра видео память увеличивается на 10-15 мб, у кого какие есть идеи на этот...

Папка Windows занимает больше места чем все файлы в ней
Доброго времени суток всем. Относительно недавно столкнулся с проблемой: Стало исчезать свободное место на диске С, на сам диск у меня...

На какой h ево Eк будет в 3 раза больше чем Eп
2.Камень отпускаетса без начальной V c h=20 м. На какой h ево Eк будет в 3 раза больше чем Eп


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru