• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Стеки

  • Автор темы Автор темы bulding
  • Дата начала Дата начала

bulding

Новые
Регистрация
10 Дек 2012
Сообщения
26
Реакции
0
Баллы
0
Стеки

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


Добавлено:
С помощью массивов я сделал. Помогите реализовать это все с помощью списков.


Код:
#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;
}

Не стоит создавать дубликаты тем. Это запрещено правилами форума. Модератор.
 
Будет время, напишу.
 
Назад
Сверху