Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
-1 / 18 / 7
Регистрация: 21.04.2019
Сообщений: 493
1

Удалить каждый k-й элемент кольцевого списка

24.04.2022, 15:29. Показов 360. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Надо переписать программу, она работает, но нужно, чтобы узлы из кольцевого списка удалялись не последовательно 1,2,3..., а удалялся каждый k-й элемент. Например, ввожу k=4, и выводится:
1->2->3->4->5->6->7->8->9->1
1->2->3->4->6->7->8->9->1
1->2->3->4->6->7->8->1
1->2->3->6->7->8->1
2->3->6->7->8->2
2->3->6->8->2
2->3->8->2
2->3->2
2->2

Отсчитывает от текущего k-раз и удаляет элемент, и так до конца


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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#include <iostream>
#include <stdlib.h>
//СТРУКТУРА БУДЕТ ЭЛЕМЕНТОМ СПИСКА
using namespace std;
  struct Node //или просто Звено списка
    {
       int x; //инфо данные структуры
       Node *Next; //Указатель не следующее звено
    };
 
//КЛАСС СПИСОК
 
class List
{
    Node *Head,*Tail; //Указатели на начало списка и на конец
public:
     List():Head(NULL),Tail(NULL){}; //Инициализация указателей как пустых
     ~List(); //Деструктор для освобождения памяти от всего что будет
     void Add(int x); //Функция заполнения структуры Node и добавления её в список как элемента
     void Show(); //Функция отображения списка List 
     void del(); //Функция изъятия элемента
 
 };
 
 
List::~List() //ДЕСТРУКТОР ДЛЯ ОЧИСТКИ ПАМЯТИ
{
 Node *temp=Head; //Временный указатель на начало списка
 while (temp!=NULL) //Пока в списке что-то есть
 
   {
     temp=Head->Next; //Резерв адреса на следующий элемент списка
 
     delete Head;  //Освобождение памяти от первой структуры как элемента списка
 
     Head=temp;  //Сдвиг начала на следующий адрес, который берем из резерва
 
   } 
}
 
 
//ФУНКЦИЯ ЗАПОЛНЕНИЯ ИНФОРМАЦИОННЫХ ПОЛЕЙ СТРУКТУРЫ NODE И ДОБАВЛЕНИЯ ЭТОЙ СТРУКТУРЫ В СПИСОК
 
void List::Add(int x)
{
    Node *temp=new Node; //Выделение памяти для нового звена списка
    temp->x=x; //Временное запоминание принятого параметра x
    temp->Next=NULL; //Указание, что следующее звено новосозданной структуры пока пустое
 
    if (Head!=NULL) //Если список не пуст 
    {
        Tail->Next=temp; //Указание, что следующее звено списка это новосозданная структура
        Tail=temp;      
    }     else Head=Tail=temp; //Если список не пуст, добавление первого элемента
}
 
 
//ФУНКЦИЯ ОТОБРАЖЕНИЯ СПИСКА НА ЭКРАНЕ 
void List::Show()
{
    Node *temp=Head; //Временный указатель на начало списка
     while (temp!=NULL) //Пока в списке что-то встречается
     {
         cout<<temp->x<<" "; //Выводим значения из списка на экран
         temp=temp->Next; //Сдвигаем указатель на начало на адрес следующего элемента
     }
    cout<<endl;
} 
 
 
 
//ФУНКЦИЯ ИЗЪЯТИЯ ЭЛЕМЕНТА ИЗ ОЧЕРЕДИ 
void List::del()
{
    if (Head!=NULL)  //Если список не пустой
    {
        Node *temp=Head; //Обращаемся к началу списка с помощью вспомогательного указателя
        cout<<"ЭЛЕМЕНТ" <<Head->x<<" ВЫШЕЛ"<<endl;
        Head=Head->Next; //Сдвиг начала списка
        delete temp; //Освобождение памяти от предыдущего звена списка
    }
}
 
 
 
int main()
{
    setlocale(0,"");
   List lst;
   system("CLS");
       lst.Add(100);  //100
       lst.Add(200);  //100   200
       lst.Add(300);  //100   200   300
          lst.Show();  // =100 200 300
            lst.del();   // =200   300 (100 Первым вошел, Первым ушел)
            cout<<endl; //просто чтоб лучше видно было
 
 
      lst.Add(111);  //200   300   111
      lst.Add(222);  //200   300   111   222  
          lst.Show();  // = 200 300 111 222
      lst.Add(999);  //200   300   111   222   999
         lst.del();    // = 300 111 222 999 (200 Вторым пришел, вторым ушел)
         lst.del();    // = 111 222 999
         cout<<endl; //просто чтоб лучше видно было
 
 lst.Show();    //  = 111 222 999
 
   system("PAUSE");
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.04.2022, 15:29
Ответы с готовыми решениями:

Задача Иосифа Флавия. Удалить каждый второй элемент из списка и в конце вывести на экран последний оставшийся элемент
Создать циклический список, в котором находятся элементы от 1 до N. Нужно написать программу,...

Функция: удалить из списка каждый N-ый элемент
В составе программы описать функцию, которая удаляет из списка каждый N элемент.

Из списка удалить каждый второй элемент
Из созданного списка удалить каждый второй элемент

Нужно удалить каждый второй элемент из циклического двухсвязного списка
Помогите найти ошибку, постоянно удаляет не то, что нужно, на данный момент выбивает ошибку. Буду...

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

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

Из созданного списка удалить каждый нечетный элемент
Помоги написать кнопку &quot;фильтрации&quot; для удаления нечетных числ с Memo....

Удалить определенный элемент кольцевого списка, а так же весь список
Здравствуйте. у меня задание сделать кольцевой список. Добавление я сделал вывод. задание свое. так...

Удалить каждый М-ый элемент списка
Помогите дописать функцию удаление каждого М-ого элемента списка, уже несколько дней над ней сижу...

Удалить каждый 3 элемент списка
Я разобрался со списками но не могу понять как написать функцию которая будет удалять каждый 3...

Удалить каждый третий элемент из списка
Написать прогу создания и обработки списка(беда), каждый элемент которого ссылается на предыдущий и...


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

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