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

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

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

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
#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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.05.2013, 12:42
Ответы с готовыми решениями:

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

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

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

3
 Аватар для DiffEreD
1458 / 795 / 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
 Аватар для DiffEreD
1458 / 795 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
04.05.2013, 18:01 4
Bulding, ну так садитесь и пишете свой собственный класс стека на основе списков, переопределите в нем нужные методы, протестируйте и пользуйтесь своим новым классом. За вас я его точно писать не собираюсь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.05.2013, 18:01
Помогаю со студенческими работами здесь

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

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

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

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

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


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Winforstrap или красявый дизайн своими руками на HTML+JS+Winform­s
anomal6 04.03.2025
Сидел тут вечером ковырял проект на MAUI, и как же глупо создаются пакеты MSIX и система обновлений пакета публикации, но не об этом. Бывает нужен современный дизайн программы а писать на MAUI,. . .
Формат данных для симуляции физики, посредством распространённы­­­­­­­х не обученных моделей.
Hrethgir 04.03.2025
Что-то как-то снова потерялось, зато катангенсы закатангесились в одном сообщении. На днях писал, что планирую для работы апгрейдить (на этот раз удачно) девайс для работы (конкретно - здоровья для,. . .
Концепция variadic
CoderHuligan 04.03.2025
Мне не очень нравится (а кому это нравится?) что у нас есть отдельно компилятор, отдельно линковщик, причем со своим собственным командным языком. При этом усложнении надо знать помимо языка. . .
Java Record или Kotlin Data Class: что лучше для неизменяемых данных
Wired 04.03.2025
Java Record и Kotlin Data Class — два мощных инструмента для обуздания неизменяемых структур данных, каждый со своим уникальным подходом к решению этой задачи. История их появления весьма. . .
Создание производительны­­­х API с Java и gRPC
Wired 04.03.2025
В мире микросервисной разработки вопрос производительности часто становится краеугольным камнем. И хотя REST API давно завоевал сердца разработчиков своей простотой и интуитивностью, при высоких. . .
Что нового в JDK 24
Wired 04.03.2025
JDK 24 — это настоящий прорыв в эволюции Java, который кардинально меняет правила игры. В этом релизе разработчики Oracle наконец-то довели до ума множество критически важных улучшений в. . .
Разработка блокчейн с использованием Java: смарт-контракты и dApp
Wired 04.03.2025
Погружаясь в мир блокчейн-разработки на Java, разработчик получает доступ к внушительному арсеналу инструментов. В отличие от Solidity, который "заперт" в экосистеме Ethereum, Java предоставляет. . .
WebAssembly в Kubernetes
stackOverflow 03.03.2025
В современной экосистеме облачных технологий WebAssembly (Wasm) становится все более значимым компонентом, предлагая уникальный подход к выполнению кода в распределенных системах. Эта технология. . .
GitHub Actions или Jenkins: Выбираем CI/CD платформу
stackOverflow 03.03.2025
Непрерывная интеграция и развертывание (CI/ CD) изменили подход к разработке программного обеспечения, превратив его в бесшовный процесс от написания кода до развертывания в продакшн. GitHub Actions и. . .
Автоматизация тестирования Pull Request в Kubernetes: Интеграция с GitHub Actions и GKE
stackOverflow 03.03.2025
Масштабные проекты с использованием Kubernetes требуют надежной системы тестирования изменений перед их внедрением в продакшн-среду. Традиционный подход с ручной проверкой Pull Request не справляется. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru