Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 43

двунаправленный список.

29.05.2011, 22:49. Показов 3333. Ответов 26
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
Прощу помочь с заданием которое звучит так :
Построить кольцевой двунаправлений список. Значения элементов считать из файла.
Определить, есть ли в списке хотяб один элемент, который равен элементу , что идет за ним по кругу. Вывести такие элементы. Удалить из списка все элементы у которых одинаковые "соседы"(первый и последний считать соседами).

Смог реализовать сам список и загрузку из файла, но вот как сравнивать текущий и предидущим не понимаю.
Буду рад любой помощи.
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include "stdafx.h"
#include "string.h"
#include "stdlib.h"
#include "conio.h"
#include "iostream"
 
using namespace std;
struct Item 
{
char data[50];        
 
Item *next;      
Item *prev;     
 
};
 
Item*head,*current, *last;
char str[50];
int n1, n2;
FILE*file;
 
void add(char* val)
{
    if(head==0)
    {
    head = new Item;
    strcpy(head->data,val);
    head->next=head;
    head->prev=head;    
    last=head;
    }else
    {
    current=new Item;
    strcpy(current->data,val);
    current->prev=last; // пред элем = конец списка
    current->next=head; // след элем = начало списка (замыкание списка 1й этап)
    last->next=current; // у текущего посл элем-та след эл = тот который только что создали
    last=current; // и этот же элемент который создали будет последним т.к добавили в конец
 
    head->prev=last; // замыкание списка (2-ой этап)
    }
}
void show()
{
    current=head;
    cout << endl << "List:" << endl;
    while(current!=head->prev)
    {
    cout << current->data << " ";
    current=current->next;
    }
    cout << endl;
 
}
int main()
{
head = NULL;
last = NULL;
do{
    system("cls");
int key;
    cout<<"1. Read list from file."<<endl;
    cout<<"2. Show list."<<endl;
    cout<<"3. Show same elements"<<endl;
    cout<<"4. Delete same elements."<<endl;
    cout<<"5. Exit."<<endl;
    cout<<"\nChoose menu item: ";
    cin>>key;
        switch(key)
        {
        case 1:{file = fopen("list.txt", "r+"); while(!feof(file))
               {fscanf(file,"%c",&str); add(str);}
               fclose(file);
                cout<<"The list is created!"<<endl; 
                system("pause");break;}
        case 2:{show();system("pause");break;}
        //case 3:{compare();system("pause");break;}
        //case 4:{del();system("pause");break;;
        case 5:{exit(1);}
        default:{cout<<"Error"<<endl;break;}
        }
    }while(1);
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.05.2011, 22:49
Ответы с готовыми решениями:

Двунаправленный список
Вопросы: Почему ругается при таком описании, говорит ; пропустил spis_fam * Create_first(char *); //формирование первого элемента ...

двунаправленный список
Нужно сделать добавление элемента в список именно в то место,из которого его удаляем #include &lt;iostream&gt; #include...

двунаправленный список
Двунаправленный список.Найти сумму первого и последнего элементарных.Заранее спасибо

26
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 43
30.05.2011, 12:41  [ТС]
Студворк — интернет-сервис помощи студентам
Буду ждать Вас, но не откажусь и от другой помощи!
На повестке ночи вопросы:
1)Как исправить то, что функция compare всегда выводит последний элемент списка, при этом никогда не сравнивая первый элемент.
2) Как удалять из списка элементы которые функция compare выводит?
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
30.05.2011, 18:05
Итак, мой вариант compare
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int compare()
{
    if (head)
    {
        Item *cur, *prev = head;
        while ((cur = prev->next) != head){ // пока хвост не замкнется
            if (strcmp(cur->data, prev->data) == 0) // проверяем не равны ли у них значения поля дата
                cout << cur->data << endl; // если равны - выводим   
            prev = cur;
        }
        if (strcmp(cur->data, prev->data) == 0) // обработка последнего или единственного элемента
            cout << cur->data << endl;
    }
    return 0;
}
Ну а с удалением что? Там же просто ссылки перед удалением надо наладить с предыдущего на следующий и наоборот. Ну и особый случай обработать, когда на удаляемый элемент указывает head и особенно когда это единственный элемент. Ну, может через некоторое время тоже набросаю.
1
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 43
30.05.2011, 22:15  [ТС]
Цитата Сообщение от grizlik78 Посмотреть сообщение
Итак, мой вариант compare
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int compare()
{
    if (head)
    {
        Item *cur, *prev = head;
        while ((cur = prev->next) != head){ // пока хвост не замкнется
            if (strcmp(cur->data, prev->data) == 0) // проверяем не равны ли у них значения поля дата
                cout << cur->data << endl; // если равны - выводим   
            prev = cur;
        }
        if (strcmp(cur->data, prev->data) == 0) // обработка последнего или единственного элемента
            cout << cur->data << endl;
    }
    return 0;
}
Ну а с удалением что? Там же просто ссылки перед удалением надо наладить с предыдущего на следующий и наоборот. Ну и особый случай обработать, когда на удаляемый элемент указывает head и особенно когда это единственный элемент. Ну, может через некоторое время тоже набросаю.
Даже так последний элемент выводиться 2жди( или 1 раз с if (feof(file)) break; в main,но в таком случае show не выводит последний элемент), при условии, что последний=первому
А вот ссылки наладить что-то совсем не выходит. битый час пробую
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
30.05.2011, 22:48
Вот такие функции у меня нормально работают, вроде.
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
void show()
{
    current = head;
    cout << endl << "List:" << endl;
    if (head)
    {
        while (current != head->prev)
        {
            cout << current->data << " ";
            current = current->next;
        }
        cout << current->data;
    }
    cout << endl;
}
 
Item* delete_node(Item *node) // удаление узла. возвращает следующий узел
{
    if (node && node->next == node)
    {
        delete node;
        head = node = NULL;
    }
    if (head)
    {
        Item *tmp = node->next;
        if (head == node)
            head = node->next;
        node->next->prev = node->prev;
        node->prev->next = node->next;
        delete node;
        node = tmp;
    }
    return node;
}
 
int del() // удаление дублей
{
    if (head)
    {
        Item *cur, *prev = head;
        while ((cur = prev->next) != head){ // пока хвост не замкнется
            if (strcmp(cur->data, prev->data) == 0) // проверяем не равны ли у них значения поля дата
                delete_node(cur); // если равны - удаляем текущий   
            else
                prev = cur;
        }
        if (strcmp(cur->data, prev->data) == 0)
            delete_node(cur);
    }
    return 0;
}
1
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 43
30.05.2011, 22:55  [ТС]
Вроде понял, как работают функции преведенные Вами. Пойду тестить.
Большое спасибо.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
30.05.2011, 23:03
Ну, в функция del() это та же compare, только повторы узлов списка не выводятся, а удаляются вызовом функции delete_node(). Ну а в ней всё просто
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Item* delete_node(Item *node) // удаление узла. возвращает следующий узел
{
    if (node && node->next == node) // выполнение условия означает, что узел только один
    {
        delete node; // удаляем его
        head = node = NULL;
    }
    if (head)
    {
        Item *tmp = node->next; // запомним следующий (на всякий случай)
        if (head == node) // если удаляемый узел — голова,
            head = node->next; // то делаем головой следующий
        node->next->prev = node->prev; // следующий связываем с предыдущим
        node->prev->next = node->next; // а предыдущий со следующим
        delete node; 
        node = tmp; // возвращать будем указатель на следующий (иногда полезно)
    }
    return node;
}
1
0 / 0 / 0
Регистрация: 29.11.2010
Сообщений: 43
30.05.2011, 23:11  [ТС]
За коментарии еще раз спасибо!
Выручили. )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.05.2011, 23:11
Помогаю со студенческими работами здесь

Двунаправленный список
Что не так с кодом может быть? Когда удаляешь первый элемент двунаправленного списка - программа крашится. Помогите пожалуйста. #include...

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

Двунаправленный список
Как в этом списке поменять ввод элементов с ручного на рандомный, помогите пожалуйста? #include &lt;iostream.h&gt; struct tochd ...

Двунаправленный список
Помогите пожалуйста удалить заданный элемент из двунаправленного списка... Напишите как это делается

Двунаправленный список
При удалении первого элемента программа крашится. В чём может быть ошибка? #include &lt;iostream&gt; #include&lt;clocale&gt; using...


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
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
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru