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

Линейный список. Удаление простых чисел из него

19.01.2016, 00:11. Показов 1416. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Построить линейный список из входной последовательности чисел. Удалить из него все простые числа

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
#include <iostream>
#include <string>
using namespace std;
 
struct list
{
    int data;
    list *next;
};
 
void add(list *&top, int pos, int x)
{
    int i, j = 1;
    list *pnew, *p = top;
    pnew = new list;
    pnew->data = x;
    if (pos<=1||top==NULL)
    {
        pnew->next = top;
        top = pnew;
    }
    else
    {
        for (int i = 1;i < pos - 1;i++)
        {
            if (p->next != NULL)
            {
                p = p->next;
                j++;
            }
        }
        if (pos <= j + 1)
        {
            pnew->next = p->next;
            p->next = pnew;
        }
    }
}
 
bool check(int num)
{
    for (int i = 2;i*i <= num;i++)
        if (num % i == 0)
            return false;
    return num > 1;
}
 
void print(list *top)
{
    list *a = top;
    while (a!=NULL)
    {
        cout << a->data << " ";
        a = a->next;
    }
    cout << endl;
}
 
void solve(list *top)
{
    list *curr = top;
    list *prev = nullptr;
 
    while (curr)
    {
        if (check(curr->data))
        {
            if (prev)
            {
                prev->next = curr->next;
            }
            else
            {
                top = curr->next;
            }
            list *tmp = curr->next;
            delete curr;
            curr = tmp;
        }
        else
        {
            prev = curr;
            curr = curr->next;
        }
    }
}
 
int main()
{
    setlocale(LC_ALL,"Russian");
    int numb,x;
    list *List = NULL;
    cout << "Введите кол-во элементов: ";
    cin >> numb;
 
    for (int i = 1;i <= numb;i++)
    {
        cin >> x;
        add(List, i, x);
    }
    print(List);
    solve(List);
    print(List);
    system("pause");
    return 0;
}
Я тут пробовал, но не получается. Помогите, пожалуйста
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.01.2016, 00:11
Ответы с готовыми решениями:

Линейный список и удаление простых чисел
Помогите пожалуйста. Построить линейный список из входной последовательности чисел. Удалить из...

Обработка одномерного массива, Удаление простых чисел из него
Требуется написать программу, которая зануляет простые числа в массиве gcc компилятор вылетает при...

Построить линейный список из входной последовательности чисел. Удалить из него все отрицательные числа
Построить линейный список из входной последовательности чисел. Удалить из него все отрицательные...

Построить линейный список из входной последовательности чисел. Удалить из него все отрицательные числа
Выполнить задание, используя односвязные списки Построить линейный список из входной...

1
Неэпический
17870 / 10635 / 2054
Регистрация: 27.09.2012
Сообщений: 26,737
Записей в блоге: 1
19.01.2016, 10:50 2
Что не получается?
0
19.01.2016, 10:50
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.01.2016, 10:50
Помогаю со студенческими работами здесь

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

Линейный алгоритм поиска простых чисел
Здравствуйте, помогите пожалуйста написать линейный алгоритм на языке си, желательно с...

Линейный однонаправленный список. Удаление элементов
Создать линейный однонаправленный список. Удалить из него все символы 'p' перед символом 'a'....

Массив целых чисел состоит из n элементов, найти сумму простых чисел, входящих в него
массив целых чисел состоит из n элементов, найти сумму простых чисел, входящих в него.


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

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