2 / 2 / 0
Регистрация: 04.04.2013
Сообщений: 27
1

Изменение коллекции во время перечисления

04.04.2013, 20:36. Показов 1786. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Я с C# работаю недолго, до этого пользовался исключительно С++. Да и сейчас бы не отказался от него... Но это история, к делу не относящаяся. Меня интересует вопрос, можно ли как-нибудь добавить в коллекцию элементы во время перечисления? В С++ для похожих целей есть очередь. Но специфика программы такова, что мне нужен набор уникальных элементов, с возможностью добавления во время перечисления. В частности, совершается обход дерева (рекурсивный и какой-то другой обход не пойдёт, самый разумный вариант именно этот) с созданием списка узлов этого дерева. От теории до гладкой работающей программы остался только один шаг. И не хочется создавать свой велосипед для решения этой задачи. Может знает кто, есть какие-нибудь способы решить проблему? Вот, собсна, код:

C#
1
2
3
4
5
6
7
8
9
10
11
12
private HashSet<Usel> GetUselList()
        {
            HashSet<Usel> list=new HashSet<Usel>();
            list.Add(head);
            HashSet<Usel>.Enumerator  i = list.GetEnumerator();
            while(i.MoveNext())
            {
                if (i.Current._true != null) list.Add(i.Current._true);
                if (i.Current._false != null) list.Add(i.Current._false);
            }
            return list;
        }
Добавлено через 2 часа 16 минут
Всё, разобрался сам. Если кому интересно будет, вот решение:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
private Queue<Usel> GetUselList()
        {
            Queue<Usel> list = new Queue<Usel>();
            list.Enqueue(head);
            Queue<Usel> list_clone = new Queue<Usel>(list);
            Usel p;
            while(list.Count>0)
            {
                p=list.Dequeue();
                if (p._true != null && !list_clone.Contains(p._true))
                {
                    list.Enqueue(p._true);
                    list_clone.Enqueue(p._true);
                }
                if (p._false != null && !list_clone.Contains(p._false))
                {
                    list.Enqueue(p._false);
                    list_clone.Enqueue(p._false);
                }
 
            }
            return list_clone;
        }
Может, и не очень изысканно, зато работает как надо.
1
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
04.04.2013, 20:36
Ответы с готовыми решениями:

Как удалить элемент из коллекции, во время перебора этой коллекции foreach?
Прив. Смотрите что. Есть сервер, на нем 2 класса - Server &amp; ClientConnection. При подключении...

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

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

Изменение значения в коллекции List<>
Здравствуйте Форумчане. Относительно недавно открыл для себя удивительный мир коллекций C# и вроде...

0
04.04.2013, 20:36
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
04.04.2013, 20:36
Помогаю со студенческими работами здесь

Parallel.Foreach изменение коллекции
Если коллекция Dictionary&lt;string,Class&gt; dic; Первый поток добавляет и удаляет элементы из...

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

Combo Box - изменение коллекции
Добрый день. Как мне сделать так, чтобы в элементе Combo Box вместо строк из коллекции при выборе...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru