Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
172 / 118 / 57
Регистрация: 08.01.2013
Сообщений: 664

Как оптимально обработать 3 миллиарда ячеек в одномерном массиве

10.06.2015, 17:04. Показов 713. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Надо обработать 3 миллиарда ячеек в одномерном массиве
Какой алгоритм посоветуете? тип переменных только short
Пробывал просто тупо переписывать ячейки в массиве, где 1024 элементов, так и не дождался конца выполнения, боялся проц или оперативка полетит(комп древний, пень 4ый одноядерный выдать с частотой 2Ггц и оперативкой 512 МБ)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.06.2015, 17:04
Ответы с готовыми решениями:

Как оптимально обработать клик по кнопке, если таковых множество
Необходимо реализовать выбор мест в самолёте, есть picture box на нём x кнопок, как собственно я узнаю на какую кнопку нажали? вешать...

Оптимально обработать результат запроса
Выполняю задачу: В базе полный бардак по взаиморасчетам с поставщиками. Правильно вели в БП, а в управленческой программе - как Бог на душу...

Оптимально обработать сильно связный граф с миллионом вершин
Всем привет, пишу на С в среде Codeblocks, нужно обработать граф с где-то миллионом вершин, причем сильно связный. У меня встает проблема...

6
Практикантроп
 Аватар для nick42
4841 / 2726 / 534
Регистрация: 23.09.2011
Сообщений: 5,798
10.06.2015, 17:11
Цитата Сообщение от bloomder Посмотреть сообщение
Какой алгоритм посоветуете?
ДОС Ассемблер.
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
10.06.2015, 17:49
Какой ДОС? 3 миллиарда ячеек.

Добавлено через 36 минут
bloomder, а можно задачу озвучить? Я вот собираю задачи, для которых нужно выделение гигабайтов памяти, просто интересно, есть ли твое задание у меня в списке...
0
 Аватар для Fulcrum_013
2083 / 1575 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
10.06.2015, 17:55
Цитата Сообщение от bloomder Посмотреть сообщение
Какой алгоритм посоветуете?
Я так думаю пилить их на винте с частичным кешированием ручками, не надеясь на винды а особенно под x86. бо как ты точно знаешь что и куда сваповать, а винда только догадывается
0
3176 / 1935 / 312
Регистрация: 27.08.2010
Сообщений: 5,131
Записей в блоге: 1
11.06.2015, 01:46
Цитата Сообщение от bloomder Посмотреть сообщение
Какой алгоритм посоветуете?
Если возможна обработка InPlace - Memory mapping, без вариантов. Обрабатывать порциями, кратными 4K (по 64 Mb, например). Если InPlace невозможен, то также порциями, кратно размеру страницы.
0
172 / 118 / 57
Регистрация: 08.01.2013
Сообщений: 664
15.06.2015, 09:44  [ТС]
Цитата Сообщение от Fulcrum_013 Посмотреть сообщение
Я так думаю пилить их на винте с частичным кешированием ручками, не надеясь на винды а особенно под x86. бо как ты точно знаешь что и куда сваповать, а винда только догадывается
а поподробнее?
0
 Аватар для Fulcrum_013
2083 / 1575 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
15.06.2015, 09:56
Цитата Сообщение от bloomder Посмотреть сообщение
а поподробнее?
Подгружаешь буффер с винта, производишь над ним преобразования, записываешь обратно. Если преобразования заключаются в комбинации по какой либо формуле разных частей этого массива, то подгружаешь порциями исходные данные в разные буфера, комбинируешь, и записываешь результирующий буфер в нужную позицию файла.

Добавлено через 3 минуты
Естественно что куда когда и что продгружать зависит от алгоритма преобразования, поэтому винда только догадывается.

Добавлено через 3 минуты
Цитата Сообщение от bloomder Посмотреть сообщение
так и не дождался конца выполнения, боялся проц или оперативка полетит
Пропускная способность проц/оперативка гораздо выше пропускной способности винта, поэтому при своповании они по большому счету "отдыхают" пока винт пишет/читает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.06.2015, 09:56
Помогаю со студенческими работами здесь

Программа заполняет массив случайными числами от 1 до 50 .В массиве 15 ячеек.Найти сумму всех ячеек в массиве.
Программа заполняет массив случайными числами от 1 до 50 .В массиве 15 ячеек.Найти сумму всех ячеек в массиве.(Использовать цикл с...

Оптимально изменить данные в массиве
Здравствуйте! Есть bool заполненный данными. Мне нужно, его проверить и если все ячейки в нем true, то сбросить их все в false. Вроде...

Как сравнить обработать данные в многомерном массиве?
Есть такой многомерный массив: http://pastebin.com/wmTmw8ZR Какие операции нужно над ним произвести чтобы получить среднее значение по...

В первом одномерном массиве найти все нечетные элементы, во втором одномерном массиве найти все четные элементы и из них сформировать массив
1. Ввести одномерный массив используя генератор случайных чисел. Одномерный массив может быть целочисленного или вещественного типа....

Как в одномерном массиве проводится сравнение
Подскажите, как доделать программу: Задание: Дан одномерный массив длиной N. Массив заполняется датчиком случайных чисел (лучше...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru