Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 13.12.2012
Сообщений: 47
1

Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки

04.05.2013, 12:42. Просмотров 593. Ответов 3
Метки нет (Все метки)

Здравствуйте. Помогите пожалуйста с программой
Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки. Программу реализовать с помощью массивов и односвязных списков. С помощью массивов я сделал. Помогите реализовать это все с помощью списков.

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
#include <iostream>
using namespace std;
 
int main()
{
    setlocale ( LC_ALL, "russian" );
    int n = 3;
    int stek_a [n], stek_b [n], stek_c [n + n];
    int v_a = -1, v_b = -1, v_c = -1;
    char s;
    bool f = true;
    // Заполнение стека 1
    while (( v_a < n-1 ) && ( f == true ))
    {
        v_a ++;
        cout << "Vvedite elementi steka A: ";
        cin >> stek_a [v_a];
        cout << "Zelaete li prodolzit? (y/n): ";
        cin >> s;
        if ( s == 'n' )
        f = false;
    }
    // Заполнение стека 2
    while (( v_b < n-1 ) && ( f == true ))
    {
        v_b ++;
        cout << "Vvedite elementi steka B: ";
        cin >> stek_b [v_b];
        cout << "Zelaete li prodolzit? (y/n):  ";
        cin >> s;
        if ( s == 'n' )
        f = false;
    }
    // Заполнение стека 3
    while (( v_a > -1 ) || ( v_b > -1 ))
    {
        if (( v_a > -1 ) && ( v_b > -1 ))
        {
            if ( stek_a [v_a] >= stek_b [v_b])
            {
                v_c ++;
                stek_c [v_c] = stek_a [v_a];
                v_a --;
            }
            else
            {
                v_c ++;
                stek_c [v_c] = stek_b [v_b];
                v_b --;
            }
        }
        if (( v_a == -1 ) && ( v_b > -1 ))
        {
            v_c ++;
            stek_c [v_c] = stek_b [v_b];
            v_b --;
        }
        if (( v_b == -1 ) && ( v_a > -1 ))
        {
            v_c ++;
            stek_c [v_c] = stek_a [v_a];
            v_a --;
        }
    }
    while ( v_c > -1 )
    {
        cout << "Element " << v_c << "steka C = " << stek_c [v_c] << endl;
        v_c --;
    }
    system ( "pause" );
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
04.05.2013, 12:42
Ответы с готовыми решениями:

Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки
Из двух стеков равной длины с вещественными числами создать 1 стек с квадратами значений элементов...

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

Из нечетных элементов двух стеков с упорядоченными элементами создать новый стек с упорядоченными элементам
Из нечетных элементов двух стеков с упорядоченными элементами создать новый стек с упорядоченными...

Создать однонаправленный список с упорядоченными по возрастанию элементами
Fisierul text INPUT.TXT contine pe fiecareb linie cite un numar real. Scrieti un program, fara a...

3
1450 / 787 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.05.2013, 14:42 2
Стек?
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
#include <iostream>
#include <vector>
#include <algorithm>
#include <stack>
 
template<typename T>
void copy_stack(std::stack<T> stck, std::stack<T>& result)
{
   while (!stck.empty())
   {
      result.push(stck.top());
      stck.pop();
   }
}
 
template<typename T>
void print_stack(std::stack<T> stck)
{
   while (!stck.empty())
   {
      std::cout<<stck.top()<<" ";
      stck.pop();
   }
   std::cout<<std::endl;
}
 
template<typename T>
void sort_stack(std::stack<T>& stck)
{
    std::vector<T> temp_copy;
    while (!stck.empty())
    {
       temp_copy.push_back(stck.top());
       stck.pop();
    }
    std::sort(temp_copy.begin(), temp_copy.end());
    
    for (std::size_t i = 0; i<temp_copy.size(); ++i)
    {
        stck.push(temp_copy[i]);
    }
}
 
int main()
{
    std::stack<int> st1{std::stack<int>::container_type{1,2,3,4}};
    std::stack<int> st2{std::stack<int>::container_type{5,6,7,8}};
    std::stack<int> result;
    
    copy_stack<int>(st1, result);
    copy_stack<int>(st2, result);
    
    print_stack<int>(st1);
    print_stack<int>(st2);
    
    sort_stack<int>(result);
    print_stack<int>(result);
    
    std::cout<<"\n";
    return 0;
}
0
0 / 0 / 0
Регистрация: 13.12.2012
Сообщений: 47
04.05.2013, 14:55  [ТС] 3
с помощью списков
0
1450 / 787 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.05.2013, 18:01 4
Bulding, ну так садитесь и пишете свой собственный класс стека на основе списков, переопределите в нем нужные методы, протестируйте и пользуйтесь своим новым классом. За вас я его точно писать не собираюсь.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
04.05.2013, 18:01

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Вывести список с чётными элементами упорядоченными по возрастанию
Дорогие форумчане, помогите, часть выполнил, со второй загвоздка: &quot;вывести список с чётными...

Заполнить третий стек общими элементами для первых двух стеков
Даны два стека и необходимо заполнить третий общими элементами для первый двух. Не знаю как...

Ввести двумерный массив 10х10 и создать одномерный массив с упорядоченными по убыванию элементами двумерного массива.
Здравствуйте, срочно нужна помощь! 1. Ввести двумерный массив 10х10 и создать одномерный массив...

Объединить файлы в новый файл так, чтобы его элементы также оказались упорядоченными по возрастанию
Даны два файла вещественных чисел с именами S1 и S2, элементы ко- торых упорядочены по...

Объединить два файла в новый файл так, чтобы его элементы оказались упорядоченными по возрастанию
Даны два файла вещественных чисел с именами S1 и S2, элементы которых упорядочены по возрастанию....

Из двух стеков, хранящих слова, создать новый стек элементов, у которых первая и последняя буква совпадают
Из двух стеков, хранящих слова, создать новый стек, у которых первая и последняя буква совпадают....


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

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

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