Форум программистов, компьютерный форум CyberForum.ru

удаление одинаковых элементов из односвязного и двусвязного списков - C++

Восстановить пароль Регистрация
 
vasilisushka
Сообщений: n/a
27.11.2013, 16:42     удаление одинаковых элементов из односвязного и двусвязного списков #1
нужно найти одинаковые элементы в односвязном и двусвязном списках и удалить их из обоих.
наброски есть, частично рабочие. т. е. удаляются элементы в двусвязном списке, только если встречаются 1 раз. остальные остаются. из односвязного ничего не удаляется.

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
int k;
     if (f1&&f2)
     {
         p1=un1;     
         while(p1)
         {
             k=0;
             p2=un2;
                    while (p2)
             {
                        if(p1->key==p2->key)
                 {
                     k++;
                     if (p2==un2)
                     {
                         un2=p2->next;
                         p2->next->prev=NULL;
                         p2=p2->next;
                         break;
                     }
                                 else
                     if (p2==uk2)
                     {
                         uk2=p2->prev;
                         p2->prev->next=NULL;
                         p1=p1->next;
                         break;
                     }
                     else
                     {
                         if(p2->next)
                         p2->next->prev=p2->prev;
                        else
                         {
                             uk2=p2->prev;
                             if(uk2) uk2->next=NULL;
                         }
 
                         if(p2->prev)
                             p2->prev->next=p2->next;
                         else
                         {
                             un2=p2->next;
                             if(un2) un2->prev=NULL;
                        }
                         delete (p2);
                         p2=NULL;
                          }
                 }
                                 
                  p2=p2->next;
             }
             p1=p1->next;
             cout<<k;
 
             if (k)
             {
                 
                    if ((p1==un1)&&(!flag))
                    {
                         un1=p1->next;
                         
                    }
                 
 
                 if((p1->next)&&(flag))
                     p1=p1->next;
             }
             flag++;
         }
     }
помогите пожалуйста!

Добавлено через 2 часа 17 минут
ребятушкиии! помогите пожалуйста!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.11.2013, 16:42     удаление одинаковых элементов из односвязного и двусвязного списков
Посмотрите здесь:

Удаление элемента из двусвязного списка C++
C++ Удаление нескольких элементов из односвязного списка
Удаление элемента из двусвязного списка C++
добавление и удаление элементов из двусвязного списка C++
C++ Удаление структуры из двусвязного списка
C++ Удаление элемента из двусвязного списка по значению
C++ Удаление из двусвязного циклического списка
C++ Замена первой группы одинаковых элементов на последнюю группу одинаковых элементов

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 00:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru