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

В списке нужно найти и удалить все четные элементы списка

10.06.2013, 17:51. Показов 3318. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно написать программу, которая из последовательности целых чисел (длинна произвольная) формирует односвязный список. В списке нужно найти и удалить все четные элементы списка.
Помогите пожалуйста, для зачета надо Заранее спасибо
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.06.2013, 17:51
Ответы с готовыми решениями:

Нужно удалить из односвязного списка четные элементы
Задание: Построить список натуральных чисел длинной N. Сжать полученный список, убрав все четные числа. В коде ниже я ввожу элементы,...

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

Удалить из списка L все четные положительные элементы
Нужна помощь в дописание программы. Одну процедуру я уже описал(DEL_CHET_POL_EL : процедура, которая удаляет из списка L все четные...

1
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
10.06.2013, 19:08
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
typedef struct node_t
{
   int value;
   struct node_t* next;
}  TNode;
 
//-----------------------------------------------------------------------------
TNode* Push(TNode** list, int value)
{
   TNode* node = (TNode*) malloc(sizeof(TNode));
   node->value = value;
   node->next = *list;
 
   *list = node;
 
   return *list;
}
//-----------------------------------------------------------------------------
int Pop(TNode** list)
{
   TNode* node = *list;
   *list = node->next;
   int value = node->value;
   free(node);
 
   return value;
}
//-----------------------------------------------------------------------------
void Clear(TNode** list)
{
   for (; *list; Pop(list)) { ; }
}
//-----------------------------------------------------------------------------
int IsEvenElement(int value)
{
   return (value & 1);
}
//-----------------------------------------------------------------------------
TNode** Find(TNode** list, int (*func)(int))
{
   TNode** node = list;
 
   for (; *node && !func((*node)->value); node = &(*node)->next) { ; }
 
   return node;
}
//-----------------------------------------------------------------------------
TNode* Remove(TNode** list, int (*func)(int))
{
   TNode** node = Find(list, func);
 
   while (*node)
   {
      Pop(node);
      node = Find(node, func);
   }
 
   return *list;
}
//-----------------------------------------------------------------------------
void Print(const TNode* list)
{
   for (; list; list = list->next)
   {
      printf("%d, ", list->value);
   }
   printf("\b\b \n");
}
//-----------------------------------------------------------------------------
int Random(int min, int max)
{
   return (rand() % (max - min + 1) + min);
}
//-----------------------------------------------------------------------------
TNode* GetRandomList(size_t length, int min, int max)
{
   TNode* list = NULL;
 
   while (length--)
   {
      Push(&list, Random(min, max));
   }
 
   return list;
}
//-----------------------------------------------------------------------------
 
int main()
{
   srand(time(NULL));
 
   TNode* list = GetRandomList(rand() % 20 + 1, 10, 90);
 
   Print(list);
 
   Remove(&list, IsEvenElement);
 
   Print(list);
 
   Clear(&list);
 
   return EXIT_SUCCESS;
}


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

Удалить из списка L все элементы, которые есть в списке L1
Используйте линейные списки для хранения последовательности чисел. Опишите процедуру или функцию, которая: a) вставляет в список L за...

Удалить из списка все четные по значению элементы. Что прописать в goal?
есть задание:Удалить из списка все четные по значению элементы есть решение DOMAINS list = integer* PREDICATES f(list, list) ...

В связном списке, содержащем целые числа, удалить все отрицательные элементы списка
Нужна помощь со свзяны списком, срочно!

Создать список действительных чисел. Удалить четные элементы списка и перемножить все положительные нечётные
Создать список действительных чисел. Удалить четные элементы списка и перемножить все положительные нечётные. начал писать код,но...

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru