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

Создать массив указателей на Person и использовать его со всеми производными классами - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти максимум среди сумм элементов диагоналей, параллельных главной http://www.cyberforum.ru/cpp-beginners/thread1251697.html
По заданию, дана квадратная целочисленная матрица, нужно найти максимум среди сумм элементов диагоналей, параллельных главной диагонали. Ошибка где то в конце, так как если максимальная сумма находится ниже главной диагонали то программа это игнорирует и выводит максимум только из верхней части. К тому же программа не читается на 2012 вижуал студии. Вот программа: #include <stdio.h>...
C++ Определить сколько чисел больше своих “соседей” Задача 2. Дано 20 целых чисел. Определить сколько из них больше своих “соседей”, т.е. преидущего и последуещего. http://www.cyberforum.ru/cpp-beginners/thread1251690.html
Определить сколько чисел принимают максимальное значение C++
Задача 1. Дано 20 действительных чисел. Определить сколько из них принимают максимальное значение.
C++ Определить, является ли множество X подмножеством множества Y
Рассматривая массивы X, Y и Z как представление некоторых множеств из объектов типа индекс (X=TRUE, если элемент k принадлежит множеству X, и X=FALSE иначе, и т.п.), реализовать следующую операцию над этими массивами-множествами: переменной t присвоить значение TRUE, если множество X является подмножеством множества Y, и значение FALSE иначе.
C++ Найти минимальный элемент последовательности из 10 чисел, парный элемент которой вычисляется по формуле http://www.cyberforum.ru/cpp-beginners/thread1251664.html
Найти минимальный элемент последовательности из 10 чисел, четный элемент которой вычисляется по формуле i + 5.8, а нечетный: i - 2.0. Программа не всегда считает элементы, например считает минимальный элемент, а максимальный нет, и на оборот. #include <iostream> using namespace std; void main() { setlocale(0, ""); int maximum, element; double minimal_element, maximal_element,...
C++ Ошибки при создании условий Exception пытаюсь обезопасить вводимые даные в перегруженый метод потоков, но в цикле вылезли ошибки(странные). Что делать? obj.Last_Name типа string. FormatException - класс. Вот ерроры Error 1 error C3867: 'std::basic_string<char,std::char_traits<char>,std::allocator<char>>::length': function call missing argument list; use '&std::basic_string<char,std::char_traits<char>,std::allocator<char>>::length'... подробнее

Показать сообщение отдельно
aesarine
0 / 0 / 0
Регистрация: 05.09.2014
Сообщений: 8

Создать массив указателей на Person и использовать его со всеми производными классами - C++

05.09.2014, 19:54. Просмотров 333. Ответов 10
Метки (Все метки)

Всем привет, это моя первая тема на форуме, поэтому сорри, если что не так.
В местном поиске ничего подобного не нашел. Гугл тоже не помог.

Есть базовый класс Person и два производных: Killer и Sniper.
Собственно, хочу создать массив указателей на Person и использовать его со всеми производными классами.
Проблема в том, чтобы размер массива вводил пользователь.
Если делаю так, то выдает ошибку "значение должно иметь константное значение":

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
short sz, ch;
 
std::cout << "Сколько добавить человек? ";
while (!(std::cin >> sz) || (sz < 1))
{
    std::cin.clear(); std::cin.sync();
}
 
// Ошибка...
Person *person[sz];
 
for (int i = 0; i < sz; i++) {
    std::cout << "Добавить человека: 1 - киллер; 2 - снайпер. ";
    while (!(std::cin >> ch) || (ch > 2) || (ch < 1))
    {
        std::cin.clear(); std::cin.sync();
    }
 
switch (ch) {
case 1:
    person[i] = new Killer;
    break;
case 2:
    person[i] = new Sniper;
    break;
}
Программа нормально работает, если SZ сделать константой.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru