Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
Igor92
0 / 0 / 0
Регистрация: 09.07.2012
Сообщений: 7
1

Преобразовать стек в два стека - первый должен содержать только чётные числа, второй — только нечётные

10.07.2012, 18:32. Просмотров 1494. Ответов 2
Метки нет (Все метки)

Здравствуйте!!
Нужно создать стек в диапазоне -50 до 50.Преобразовать стек в два стека.Причем, первый должен содержать только чётные числа,второй - только нечётные.
НА СИ
ПЖЛСТ

Добавлено через 45 секунд

вот код для с++
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
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <stack>
 
using namespace std;
 
int main() {
    unsigned i, count;
    cout << "Count of elements: ";
    cin >> count;
    srand((int)time(0));
    stack<signed char> s1;
    for (i = 0; i < count; i++)
        s1.push(rand() % 101 - 50);
    stack<signed char> s2, s3;
    signed char c;
    while (!s1.empty()) {
        cout << int(c = s1.top()) << endl;
        (c & 1? s3: s2).push(c);
        s1.pop();
    }
    cout << endl;
    while (!s2.empty()) {
        cout << int(s2.top()) << endl;
        s2.pop();
    }
    cout << endl;
    while (!s3.empty()) {
        cout << int(s3.top()) << endl;
        s3.pop();
    }
}
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.07.2012, 18:32
Ответы с готовыми решениями:

Создать два списка: первый должен содержать только положительные, а второй – только отрицательные числа
Создать два списка. Первый должен содержать только положительные, а второй – только отрицательные...

Преобразовать стек в два стека
Здравствуйте. Завтра сдача. ЗАранее Спасибо!!!! Ошибка (21,42) Cannot convert 'void *' to ' Node...

Преобразовать стек в два стека
Нужно создать стек в диапазоне -50 до 50.Преобразовать стек в два стека.Причем, первый должен...

Разность массивов A и B (результат должен содержать только элементы массива A, которых нет в массиве B)
Ввести два массива целых чисел A(n), B(m), n, m &lt; 30. Получить новый массив, представляющий...

Преобразовать стек в два стека. Первый должен содержать только четные числа, а второй – нечетные
Сессия грядет , ребята выручайте! 2. Сформировать динамический список (стек), считая, что длина...

2
easybudda
Модератор
Эксперт JavaЭксперт CЭксперт С++
10297 / 6179 / 1555
Регистрация: 25.07.2009
Сообщений: 11,762
10.07.2012, 19:22 2
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Не по теме:

Цитата Сообщение от Igor92 Посмотреть сообщение
вот код для с++
Где взял?


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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define bounded_random(l, h) ( rand() % ((h) - (l) + 1) + (l) )
 
typedef struct NODE {
    int value;
    struct NODE * next;
} node_t;
 
int push(node_t ** pStack, const int nValue) {
    node_t * pNode = malloc(sizeof(node_t));
    if ( ! pNode )
        return -1;
    
    pNode->value = nValue;
    pNode->next = *pStack;
    *pStack = pNode;
    
    return 0;
}
 
int pop(node_t ** pStack, int * pValue) {
    if ( ! *pStack )
        return -1;
    else { 
        node_t * pNode = (*pStack)->next;
        *pValue = (*pStack)->value;
        free(*pStack);
        *pStack = pNode;
    }
    
    return 0;
}
 
#define LOW (-50)
#define HIGH (50)
 
int main(void) {
    size_t count;
    
    srand(time(NULL));
    
    while ( printf("Number of elements: ") && scanf("%u", &count) == 1 && count ) {
        node_t * all, * even, * odd;
        int curr;
        
        all = even = odd = NULL;
        while ( count-- ) {
            if ( push(&all, bounded_random(LOW, HIGH)) ) {
                fprintf(stderr, "Memory error!\n");
                exit(1);
            }
        }
        
        printf("All:\n");
        while ( ! pop(&all, &curr) ) {
            printf("%d ", curr);
            if ( curr & 1 ) {
                if ( push(&odd, curr) ) {
                    fprintf(stderr, "Memory error!\n");
                    exit(1);
                }
            }
            else {
                if ( push(&even, curr) ) {
                    fprintf(stderr, "Memory error!\n");
                    exit(1);
                }
            }
        }
        
        printf("\nEven:\n");
        while ( ! pop(&even, &curr) )
            printf("%d ", curr);
        
        printf("\nOdd:\n");
        while ( ! pop(&odd, &curr) )
            printf("%d ", curr);
        
        printf("\n");
    }
    
    exit(0);
}
1
Igor92
0 / 0 / 0
Регистрация: 09.07.2012
Сообщений: 7
10.07.2012, 22:36  [ТС] 3
Код написал добрый пользователь вашего форума
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.07.2012, 22:36

Поместить в два линейных односвязных списка: в первый - чётные по порядку числа, во второй - нечётные
Разработайте программу, которая вводит с клавиатуры ввода целые числа и помещает их в два линейных...

Дан файл целых чисел. Создать два новых файла, в первый записать чётные числа исходного, во второй - нечётные
Дан файл целых чисел. Создать два новых файла, первый из которых содержит чётные числа из исходного...

Второй стек должен выводить только положительные числа с первого
#include &lt;stdio.h&gt; #include &lt;conio.h&gt; #define LEN 21 int g_count1 = 0; int g_count2 = 0;...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru