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

Как вставить элемент в двухсвязный циклический список?

30.04.2022, 16:22. Показов 379. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Классы узел и цикл.список
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
    internal class DoubleNode
    {
        private string name;
        private string destination;
        private string date;
        private int number;
        private DoubleNode next;
        private DoubleNode prev;
        public string Name
        {
            get { return name; }
            set { name = value; }
        }
        public string Destination
        {
            get { return destination; }
            set { destination = value; }
        }
        public string Date
        {
            get { return date; }
            set { date = value; }
        }
        public int Number
        {
            get { return number; }
            set { number = value; }
        }
        public DoubleNode Next { get { return next; } set { next = value; } }
        public DoubleNode Prev { get { return prev; } set { prev = value; } }
        public DoubleNode()
        { }
        public DoubleNode(string name, string destination, string date, int number)
        {
            this.name = name;
            this.destination = destination;
            this.date = date;
            this.number = number;
        }
        public DoubleNode(DoubleNode next, string name, string destination, string date, int number)
        {
            this.next = next;
            this.name = name;
            this.destination = destination;
            this.date = date;
            this.number = number;
        }
    }
    internal class CycleDoubleLinkedList // Класс “Двусвязные циклические списки”
    {
        private DoubleNode head; // ссылка на головной узел списка
        public DoubleNode Head
        {
            get { return head; }
            set { head = value; }
        }
        public CycleDoubleLinkedList()
        {
            head = new DoubleNode();
            head.Next = head;
            head.Prev = head;
        }
    }
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
       public partial class AddRequest : Form
    {
        public AddRequest()
        {
            InitializeComponent();
 
        }
        CycleDoubleLinkedList cycleDoubleLinkedList = new CycleDoubleLinkedList();
        private void InsertInDataGridView()
        {
            DoubleNode p = cycleDoubleLinkedList.Head.Next;
            int i = 0;
            while ((p != null) && (i < dataGridView1.Rows.Count))
            {
                dataGridView1[0, i].Value = p.Destination;
                dataGridView1[1, i].Value = p.Name;
                dataGridView1[2, i].Value = p.Date;
                dataGridView1[3, i].Value = p.Number;
                p.Prev = p;
                p = p.Next;
 
 
                i++;
            }
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            string _destination = textBox1.Text;
            string _name = textBox2.Text;
            DateTime date = Convert.ToDateTime(maskedTextBox1.Text);
            string _date = date.ToShortDateString();
            int _number = Convert.ToInt32(textBox3.Text);
            DoubleNode p = new DoubleNode(_name, _destination, _date, _number);
            if (cycleDoubleLinkedList.Head != null)
            {
                cycleDoubleLinkedList.Head.Next = p;
            }
            else
            {
                cycleDoubleLinkedList.Head = p;
                cycleDoubleLinkedList.Head.Next = cycleDoubleLinkedList.Head;
            }
            dataGridView1.Rows.Add(1);
            InsertInDataGridView();
        }
}
При нажатии на button1 добавляется строка с введенными данными из textbox.
В данном виде код добавляет в datagridview строку, но при этом при следующих вставках он заменяет первую строку заново введенными данными, а следующие строки остаются пустыми
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.04.2022, 16:22
Ответы с готовыми решениями:

Вставить в двухсвязный список элемент y после всех элементов списка, равных x
Вставить в двухсвязный список элемент y после всех элементов списка, равных x. Написать процедуры создания, печати и обработки списка.

Вставить элемент после найденного(Циклический двусвязный список)
Помогите, пожалуйста, реализовать вставку элемента после найденного в качестве функции типа void name(){} . struct elem { int data; ...

Вставить элемент после найденного(Циклический двусвязный список)
Помогите, пожалуйста, реализовать вставку элемента после найденного в качестве функции типа void name(){} . struct elem { int data;...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.04.2022, 16:22
Помогаю со студенческими работами здесь

Шаблон двухсвязный список, храним указатель не элемент
#include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &quot;DSpisok.h&quot; using namespace std; int main(int argc, char...

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

Реализовать двухсвязный список. Каждый элемент списка может содержать один объект
Здравствуйте, мне нужно было реализовать двухсвязный список. Каждый элемент списка может содержать один объект. Объект может быть трех...

Как сделать двухсвязный список
Информацию о величине экспорта и соответствующий номер контракта записать в двусвязный кольцевой список. На экран вывести максимальную...

Как вставить элемент в список?
Здравствуйте, сейчас изучал связные списки и возникла одна непонятка. void insert(ListNode *Sptr, char value) { ListNode...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru