Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Bulding
0 / 0 / 0
Регистрация: 13.12.2012
Сообщений: 47
04.05.2013, 12:42     Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки #1
Здравствуйте. Помогите пожалуйста с программой
Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки. Программу реализовать с помощью массивов и односвязных списков. С помощью массивов я сделал. Помогите реализовать это все с помощью списков.

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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.05.2013, 12:42     Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки
Посмотрите здесь:

C++ Значения переменных поменять местами так, чтобы они оказались упорядоченными по возрастанию
C++ Определить являются ли числа упорядоченными по возрастанию
Значение переменных поменять местами так, чтобы они оказались упорядоченными по возрастанию C++
Значение переменных поменять местами так, чтобы они оказались упорядоченными по возрастанию C++
Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 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;
}
Bulding
0 / 0 / 0
Регистрация: 13.12.2012
Сообщений: 47
04.05.2013, 14:55  [ТС]     Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки #3
с помощью списков
DiffEreD
 Аватар для DiffEreD
1420 / 757 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.05.2013, 18:01     Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки #4
Bulding, ну так садитесь и пишете свой собственный класс стека на основе списков, переопределите в нем нужные методы, протестируйте и пользуйтесь своим новым классом. За вас я его точно писать не собираюсь.
Yandex
Объявления
04.05.2013, 18:01     Из двух стеков с упорядоченными по возрастанию элементами создать новый стек с упорядоченными элементами, не удаляя исходные стеки
Ответ Создать тему
Опции темы

Текущее время: 17:49. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru