Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 1
Регистрация: 16.09.2015
Сообщений: 51

Оптимизация выборки из списка

10.05.2017, 21:11. Показов 1321. Ответов 4
Метки linq (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброе время суток! У меня есть список LIST, где хранятся значения координат. Также у меня есть участок, например 2000м на 2000м, который разбили на более мелкие участки (25 на 25 метров). Из этого исходя у меня есть сетка 80 на 80, куда мне ну;yj разместить точки из списка и подсчитать, сколько этих точек находится на каждом из этих маленьких участков (который 25 на 25 метров)

Я сделал следующий алгоритм, но на таких объемах, какие я указал в примере, программа тратит кучу времени и ресурсов для выполнения этих действий. Точек в списке примерно 400-600:
C#
1
2
3
4
5
6
7
8
9
10
                  for (int i = 0, i1 = 0; i < 2000 && i1 < 80; i = i + 25, i1 += 1)
                {
                    for (int j = 0, j1 = 0; j < 2000 && j1 < 80; j = j + 25, j1 += 1)
                    {
                       //CountSelectedPointsInBin список координат
                       // выполняю linq запрос по расчету суммы точек на нужном маленьком участке
                        int multip = CountSelectedPointsInBin.Where(p => p.PointX >= i && p.PointX <= i + SizeBinX && p.PointY >= j && p.PointY <= j + SizeBinY).Sum(p => p.NumRect);
                        // загоняю все в массив
                        arrayBin[i1, j1] = multip;
                    }
Как можно оптимизировать этот код?? Или вообще сделать по другому, чтобы программа быстрее выполняла такие не сложные операции?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.05.2017, 21:11
Ответы с готовыми решениями:

Оптимизация выборки из List большого объема
Всем добрый день! У меня есть список координат, где хранятся больше 100к записей. Я прохожу этот список двойным циклом для нахождения...

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

Оптимизация запросов выборки
/components/content/frontend.php =&gt; getArticlesCount() SELECT 1 FROM cms_content con INNER JOIN cms_category cat ON cat.id =...

4
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
10.05.2017, 21:43
Лучший ответ Сообщение было отмечено blackaleks как решение

Решение

Цитата Сообщение от blackaleks Посмотреть сообщение
Я сделал следующий алгоритм
OMG

C#
1
2
3
            var arrayBin = new int[80, 80];
            foreach (var p in CountSelectedPointsInBin)
                arrayBin[p.X/25, p.Y/25]++;
1
0 / 0 / 1
Регистрация: 16.09.2015
Сообщений: 51
10.05.2017, 22:15  [ТС]
Storm23, я извиняюсь но мне кажется что это не решает мой вопрос.
arrayBin[p.X/25, p.Y/25]++; данный код не высчитывает количество точек в определенном диапазоне..

почему в массиве, его подстроки объявлены так [p.X/25, p.Y/25]? Мне необходимо например, arrayBin[1,12] = 10.
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
10.05.2017, 22:57
Цитата Сообщение от blackaleks Посмотреть сообщение
данный код не высчитывает количество точек в определенном диапазоне..
Именно это он и делает.

Но ваш код суммирует не число точек, а некий параметр NumRect. Если переписать в ваших терминах, то код будет такой:
C#
1
2
3
            var arrayBin = new int[80, 80];
            foreach (var p in CountSelectedPointsInBin)
                arrayBin[p.PointX /25, p.PointY / 25] += p.NumRect;
0
0 / 0 / 1
Регистрация: 16.09.2015
Сообщений: 51
11.05.2017, 06:33  [ТС]
Storm23, просто я сразу не понял... слишком просто оказалось. наверно не искал легких путей когда писал этот код
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.05.2017, 06:33
Помогаю со студенческими работами здесь

Оптимизация выборки максимального значения
есть 3 таблицы: CREATE TABLE autor ( id MEDIUMINT AUTO_INCREMENT, name VARCHAR(100) NOT NULL, PRIMARY KEY (id) ); ...

Оптимизация выборки по двум периодам
всем привет. суть выборки declare @startEarlierDate DATETIME, @endEarlierDate DATETIME, @startLaterDate DATETIME, ...

Оптимизация выборки данных в PostgreSQL
Имею БД с таблицей &quot;log&quot;, в которой ~65М строк. Диск загружен не более, чем на 5%. Выполняю простой запрос SELECT * FROM log WHERE plate...

Оптимизация скорости выборки в массивах
Здравствуйте! Есть 2 массива: - в первом, к примеру, содержится следующая информация: &quot;Артикул&quot;, &quot;Фамилия&quot;,...

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


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru