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

Создать однонаправленный список, заполнить его случайным образом и удалить все отрицательные элементы

08.11.2017, 22:26. Показов 2433. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Помогите, пожалуйста, с задачей, никак не получается. Задать однонаправленный список случайной длины. Заполнить его случайным образом и удалить все отрицательные элементы.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.11.2017, 22:26
Ответы с готовыми решениями:

Заполнить массив В(3,4) случайным образом. Найти сумму положительных элементов. Все отрицательные элементы заменить на 0
Мне нужно только Все отрицательные элементы заменить на 0. Мой код: private void button1_Click(object sender, EventArgs e) {...

Заполнить одномерный массив так, чтобы все его элементы были различны и выбраны случайным образом
В Delphi создать консольные приложения (File-New-Console Application) для решения следующих задач. Каждую задачу необходимо решить с...

Создать массив размерностью 7 х 7, заполнить его случайным образом цифрами
Создать массив размерностью 7 х 7, заполнить его случайным образом цифрами 7, 5 и 2. Результат в виде матрицы записать в текстовый файл..

2
 Аватар для Геомеханик
838 / 641 / 940
Регистрация: 26.06.2015
Сообщений: 1,409
09.11.2017, 10:21
Лучший ответ Сообщение было отмечено kkketrin как решение

Решение

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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
struct node {
    node* next;
    int   val;
    node(int v):next(NULL), val(v){}
};
void slist_fill(node*& ls, int n, int a, int b);
void slist_remove(node*& ls, bool (*cmp)(int));
void slist_clear(node*& ls);
void slist_print(std::ostream& _out, const node* ls);
 
bool negative(int v) { return (v < 0); }
 
int main(void){
    srand(static_cast<unsigned int>(time(NULL)));
 
    node* ls = NULL;
    slist_fill(ls, 10 + rand() % 10, -5, 5);
    slist_print(std::cout, ls);
 
    slist_remove(ls, &negative);
    slist_print(std::cout, ls);
 
    slist_clear(ls);
    std::cin.get();
    return 0;
}
 
//удаление
void slist_remove(node*& ls, bool (*cmp)(int)){
    node* t, *p = ls, *i = ls;
    while(i != NULL){
        if((*cmp)(i->val)){
            if(ls == i)
                t = ls = ls->next;
            else
                t = p->next = i->next;
            delete i;
            i = t;
        } else {
            p = i;
            i = i->next;
        }
    }
}
 
//заполнение списка
void slist_fill(node*& ls, int n, int a, int b){
    node* p, *tl = NULL;
    for(int i = 0; i < n; ++i){
        p = new node(a + rand() % (b - a + 1));
        if(tl == NULL)
            ls = tl = p;
        else
            tl = tl->next = p;
    }
}
 
//удаление всех элементов списка
void slist_clear(node*& ls){
    node* t;
    while(ls != NULL){
        t  = ls;
        ls = ls->next;
        delete t;
    }
}
 
//печать списка
void slist_print(std::ostream& _out, const node* ls){
    for(; ls != NULL; ls = ls->next)
        _out << ls->val << ' ';
    _out << std::endl;
}
0
0 / 0 / 0
Регистрация: 17.10.2017
Сообщений: 2
12.11.2017, 00:47  [ТС]
Спасибо большое, а то только начала разбираться и достаточно сложно дается эта тема, помогли разобраться.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2017, 00:47
Помогаю со студенческими работами здесь

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

Создать двумерный массив размерности 3x3, и заполнить его числами от 1 до 9, расположенными случайным образом
1. Создать двумерный массив размерности 3x3, и заполнить его числами от 1 до 9, расположенными случайным образом.

Создать двухсвязанный список из случайных целых чисел. Удалить все отрицательные элементы списка
Задача: Создать двухсвязанный список из случайных целых чисел. Удалить все отрицательные элементы списка. При выполнении...

Создать динамический 2-мерный массив, заполнить его случайным образом, сортировать столбцы по возрастанию их суммы
Создать динамический 2-мерный массив, заполнить его случайным образом, сортировать столбцы по возрастанию их суммы. Именуйте темы...

Заполнить StringGrid случайным образом, затем заменить на введенное число все элементы, меньшие введенного
Помогить составить эту прог-му.Составить программу которая заполняет stringGrid случайным образом, затем заменить на введеное число все...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru