Как зайти в Даркнет?!
25th January, 01:11
6
0
Как в tkinter из поля ввода Entry получить значение в одну переменную и обновить строку кнопкой, затем получить ещё одно введённое значение и затем сложить их. Ниже пример кода
21st July, 19:00
895
0
Программа, которая создает фейковые сервера в поиске игровых серверов CS 1.6 Steam
21st March, 17:43
948
0
Очень долго работает Update запрос Oracle
27th January, 09:58
914
0
не могу запустить сервер на tomcat HTTP Status 404 – Not Found
21st January, 18:02
905
0
Где можно найти фрилансера для выполнения поступающих задач, на постоянной основе?
2nd December, 09:48
938
0
Разработка мобильной кроссплатформенной военной игры
16th July, 17:57
1724
0
период по дням
25th October, 10:44
3955
0
Пишу скрипты для BAS только на запросах
16th September, 02:42
3720
0
Некорректный скрипт для закрытия блока
14th April, 18:33
4613
0
прокидывать exception в блоках try-catch JAVA
11th March, 21:11
4381
0
Помогите пожалуйста решить задачи
24th November, 23:53
6086
0
Не понимаю почему не открывается детальное описание продукта
11th November, 11:51
4351
0
Нужно решить задачу по программированию на массивы
27th October, 18:01
4396
0
Метода Крамера С++
23rd October, 11:55
4309
0
помогите решить задачу на C++
22nd October, 17:31
4002
0
Помогите решить задачу на python с codeforces
22nd October, 11:11
4492
0
Python с нуля: полное руководство для начинающих
18th June, 13:58
2599
0
Удаление N элементов из списка условно
Я писал некоторый элемент управления ASP.NET , когда пришел к сценарию, в котором мне нужно было удалить элементы из списка, только когда они соответствовали определенному условию.
Метод RemoveAll универсального класса List выполняет хорошую работу, но удаляет все элементы, соответствующие условию, указанному предикатом.
Что делать, если я хочу удалить только определенное количество элементов, определяющих условие? Как вы думаете, как лучше всего это сделать?
Если метод не предоставляет параметр "limit" (чего в нем нет), то лучше всего использовать простой цикл, который удаляет совпадающие элементы, прерываясь, когда ваш инкрементированный "match counter" достигает вашего предела.
Это в значительной степени то, как работает внутренняя функция в любом случае, но в более оптимизированном виде.
Здесь полезны анонимные делегаты. Простой пример для удаления первых предельных четных чисел из списка.
List<int> myList = new List<int>;
for (int i = 0; i < 20; i++) myList.add(i);
int total = 0;
int limit = 5;
myList.RemoveAll(delegate(int i) { if (i % 2 == 0 && total < limit) { total++; return true; } return false; });
myList.ForEach(i => Console.Write(i + " "));
Дает 1 3 5 7 9 10 11 12 13 14 15 16 17 18 19, как мы хотим. Достаточно легко обернуть это в функцию, подходящую для использования в качестве выражения lambda, принимая реальный тест в качестве параметра.