Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
1 / 1 / 0
Регистрация: 08.12.2012
Сообщений: 27
1

Fixed и структуры: создать дерево

08.12.2012, 14:58. Показов 1522. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Привет всем!
Момогите,у меня следующая проблема:
Мне нужно создать дерево на с#.Так как я знаю немного С++ , я решил сделать ето с помощью указателей(Я использую "небезопасный код" ).Именно в етом направлении мне и нужно(таково задание).
Я создал структуру branch ,которая хранит указатель на папу,и 2 сыновей , значение ветки.Код:
C#
1
2
3
4
5
6
7
8
 unsafe struct branch
    {
        public int value;
        public branch* parent;
        public branch* lSon;
        public branch* rSon;
        
    }
И сам клас деревья , который будет создавать ,добавлять , кароче говоря создавать связи между обектами етих структур.Но прикол в чем: создаетса екземляр структуры нормально,все заполняетса и тд..Но когда конструктор завершает свою роботу,происходят страшные вещи..Сборщик мусора c# куда-то тянет мои екземляры структур в другое место,а указатели ,которые вказывали на них,указывают теперь на мусор...Мне нужно "зафиксировать" ети екземпляры в памяти,что б можна было к ним нормально доступится через указатель.Помогите!Как я уже не пробывал.В итоге ошибки и тд.Выставляю код класа,без fixed .Кто сможет,помогите плс!Ато я уже запарился.(сори за русский,я сам с Украины)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
unsafe class three
    {
        public branch* root;
        public branch* current;
        public three(){
            branch tmp = new branch();
 
                tmp.value = 3;
                tmp.lSon=tmp.rSon=null;
                root = &tmp;
                current = &tmp;
                Console.Write(tmp.value + "\n");
 
 
            }
            public unsafe void output()
        {
            Console.Write(this.current->value);
        }
            
       
 
    };
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.12.2012, 14:58
Ответы с готовыми решениями:

Реализация структуры данных "Дерево" (указатели на родителей)
Здравствуйте! Краткое описание проблемы: есть класс Tree, представляющий собой набор методов....

Создать дерево организационной структуры организации
Ребят, кто-нибудь знает как примерно это делать? А то я как-то даже не особо понял суть задания,...

Fixed absolute и relative. Как сделать fixed блок по центру relative родителя?
Хелп плз( сломал голову уже и поиск ни к чему толковому не привел. <div id="content"> <div...

Структуры. Бинарное дерево.
Поставлена такая задача. Является ли двоичное дерево линейным списком вершин? Реализовать надо на...

5
54 / 53 / 5
Регистрация: 14.08.2012
Сообщений: 252
08.12.2012, 15:30 2
Используйте классы, а не структуры. Во-первых структуры располагаются в стеке, поэтому они теряются сразу же как выходят из области видимости. Классы же будут существовать до тех пор, пока на них есть ссылка. Во-вторых, размер стека не позволит вам создавать динамические структуры достаточно большого размера, как того требуется, а с классами такой проблемы нет
0
1 / 1 / 0
Регистрация: 08.12.2012
Сообщений: 27
08.12.2012, 16:21  [ТС] 3
Спасибо за ответ ,но к сожелению, C# при unsafe не может использовать явные указатели на класс..(
тоисть конструкция типа:
C#
1
2
3
4
5
unsafe class Foo{
Foo* myPointer; // <--- нельзя
...
 
};
щитается ошибкой,потому что указатели в c#
Код
Любой из следующих типов может быть типом указателя,но не клас.:

sbyte, byte, short, ushort, int, uint, long, ulong, char, float, double, decimal или bool.

Любой тип enum.

Любой пользовательский тип структуры, содержащий поля только неуправляемых типов.
пруф: [URL="http://msdn.microsoft.com/ru-ru/library/y31yhkeb.aspx"]http://msdn.microsoft.com/ru-ru/library/y31yhkeb.aspx[/URL]
Так ,что вопрос остается в силе.Как сделать так,что б зафиксировать елемент структуры в Памяти ?
0
54 / 53 / 5
Регистрация: 14.08.2012
Сообщений: 252
10.12.2012, 00:01 4
Цитата Сообщение от Winfle Посмотреть сообщение
Спасибо за ответ ,но к сожелению, C# при unsafe не может использовать явные указатели на класс..(
А зачем указатели на класс? Класс и так является ссылочным типом. Вам нужно просто внутри класса создать поле типа этого класса.
C#
1
2
3
4
5
class Foo{
Foo myPointer; // "указатель" на следующий элемент цепочки
 
public Foo Next { get { return myPointer; } } //можем перемещаться по цепочке
};
1
Эксперт .NET
17791 / 12942 / 3381
Регистрация: 17.09.2011
Сообщений: 21,219
10.12.2012, 00:05 5
Winfle, возможности работы с указателями в шарпе весьма кастрированы, так что лучше забросьте эту идею и перепишите код с использованием ссылок, как посоветовали выше.
0
1 / 1 / 0
Регистрация: 08.12.2012
Сообщений: 27
11.12.2012, 13:15  [ТС] 6
Спасибо,так и сделал.Просто после перехода с С++ , себя немного не уверенно чуствую на шарпе )
Но что поделать..Уже разобрался.Спасибо всем,кто отписал.Тему можна закрывать
0
11.12.2012, 13:15
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
11.12.2012, 13:15
Помогаю со студенческими работами здесь

Создание динамической структуры дерево
Помогите пожалуйста с программой.....буду очень благодарен!!!!!!!!! Нужно написать программу по...

Запись структуры в бинарное дерево
Помогите записать структуру в дерево? Нужно записать структуру в дерево. КИНЬТЕ ПРИМЕР ПОЖАЛУЙСТА ...

Сбалансированное бинарное дерево. Структуры даннных
Доброе время суток,уважаемые посетители форума! Задали на структурах данных создать...

Динамические структуры данных (построить бинарное дерево)
Доброго времени суток,нужна помощь - &quot;построить произвольное бинарное дерево та найти в нем элемент...


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

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