С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 05.09.2014
Сообщений: 7

Оптимизация алгоритма поиска по IP адресам

08.06.2016, 22:50. Показов 617. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую, такая проблема, может кто подскажет как оптимизировать алгоритм.
Есть excel файл вида:
ip,данные 1,данные 2, данные 3,...
Данные в числовом формате(int/double), нужно добавить данные которые принадлежат к одному ип диапазону.
На данный момент делаю вот так:
1. Формирую ip диапазоны с айпишников(преобразовываю каждый ip в ип диапазон и заношу всё это дело в отдельный массив, без повторений)
2. Прогоняю циклом(Функция IsMyIP определяет, входит ли ip в диапазон):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
for (int j = 1; j < ips.Length - 1; j++)
                    {
                        string[] temp = ips[j].Split(',');
                        string current_ip = temp[0].Replace(@"""", "");
                        for (i = 0; i < ranges.Length - 1; i++)
                        {
                            string range_start = ranges[i].Split('-')[0].Replace(" ", "");
                            string range_end = ranges[i].Split('-')[1].Replace(" ", "");
                            if (IsMyIp(current_ip, range_start, range_end) == true)
                            {
                               // Действия с данными
                                break;
                            }
                        }
До этого вообще брался диапазон и проходил циклом все айпи, выходило довольно много комбинаций(кол-во диапазонов * кол-во айпи), учитывая что кол-во айпи бывало и за 100к, а кол-во диапазонов примерно столько же, сейчас вот сделал наоборот и добавил break, но это всё равно очень долго, может кто-то подскажет как можно сделать лучше?
Спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.06.2016, 22:50
Ответы с готовыми решениями:

Оптимизация алгоритма быстрого поиска
Допустим есть строка: &quot;Съешь ещё этих мягких французских булок, да выпей же чаю&quot;,и есть массив готовых строк, к примеру {...

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

Реализуйте на практике 2 алгоритма поиска и 2 алгоритма сортировки. Результаты сравните
Всем привет! Я в С++ абсолютный чайнег, поэтому за дебильные вопросы сапогами не пинайте))) в общем есть код работающий в борланде....

2
496 / 130 / 19
Регистрация: 30.03.2010
Сообщений: 224
09.06.2016, 11:05
воспользоваться средствами Excel'а:
1) в Excel'е отсортировать по ip
2) вычитать все до тех пор, пока ip не изменится
3) сделать откат/закрыть без сохранения
это только идея, т.к. непонятно, как происходит взаимодействие с Excel'ем и вычитка данных
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18250 / 14174 / 5366
Регистрация: 17.03.2014
Сообщений: 28,850
Записей в блоге: 1
09.06.2016, 11:06
Advice, преобразуй IP в число. Тогда проверка на вхождение в диапазон сведется к простому условию rangeStart <= ip <= rangeEnd.
C#
1
2
3
string ipAddress = "127.0.0.1";
int[] addrParts = ipAddress.Split('.').Select(int.Parse).ToArray();
uint ip = (uint)(addrParts[0]*256L*256*256+addrParts[1]*256L*256+addrParts[2]*256L+addrParts[3]);
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.06.2016, 11:06
Помогаю со студенческими работами здесь

Массив: К элементам по четным адресам добавить 1, из элементов по нечетным адресам вычесть 1.
К элементам по четным адресам добавить 1, из элементов по нечетным адресам вычесть 1. Четность проверять не надо так как элемент...

Оптимизация алгоритма
Условие: Дана выборка (X_i, Y_i)_{i=1}^N. Предполагается, что она была построена по следующему закону: \begin{cases} Y=\beta \xi...

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

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

Оптимизация алгоритма
Условие задачи: Лесенкой называется набор кубиков, в котором каждый более верхний слой содержит кубиков меньше, чем предыдущий. Требуется...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru