Программу на с++
Есть список игрушек, которые имеются в n детских садах.
Определить игрушки из списка: которых нет ни в одном из
детсадов; которые есть в каждом из детсадов.
Лови решение, допилил....
#include
#include
#include
using namespace std;
int main()
{
/*
Детский сад:
id - номер детского сада;
toylist - список игрушек в детском саду
*/
struct house
{
unsigned id;
vector
};
/*
Игрушка:
id - уникальный номер игрушки;
name - название игрушки
*/
struct toy
{
unsigned id;
string name;
};
// Объявляем необходимые переменные
vector
vector
toy c_toy;
house c_house;
vector
// Заполняем массив игрушек
char ch=y;
unsigned toy_id=1;
string toy_name;
do
{
cout <
c_toy.id=toy_id;
c_toy.name=toy_name;
toys.push_back(c_toy);
cout <<"Добавить ещё одну игрушку? (y/n): ";
cin >>ch;
cin.ignore();
if((ch==y) || (ch==Y))
toy_id++;
} while((ch==y) || (ch==Y));
// Выводим на экран список всех игрушек
for(unsigned i=0; i
cout <<"Игрушка " <
// Заполняем данные по детским садам
unsigned house_id=1;
unsigned toy_num;
do
{
cout <
do
{
cin >>toy_num;
t_list.push_back(toy_num);
cout <<"Добавить еще? (y/n): ";
cin >>ch;
cin.ignore();
} while((ch==y) || (ch==Y));
c_house.id=house_id;
c_house.toylist = t_list;
t_list.clear();
houses.push_back(c_house);
cout <<"Добавить ещё детский сад? (y/n): ";
cin >>ch;
if((ch==y) || (ch==Y)) house_id++;
} while((ch==y) || (ch==Y));
// Выводим данные по всем детским садам
for(unsigned i=0; i
cout <<" Детсад √" <
// Ищем игрушки, которые есть во всех детских садах
unsigned t;
bool founded = false;
vector
for(unsigned i=0; i
t=toys[i].id;
for(unsigned j=0; j
for(unsigned k=0; k
if(t==houses[j].toylist[k])
founded = true;
}
if(founded) t1.push_back(t);
founded = false;
}
unsigned h=houses.size();
if(t1.size()==h)
t2.push_back(t);
t1.clear();
}
cout <<"Игрушки, которые есть во всех детских садах:" <
cout <
// Ищем игрушки, которых нет ни в одном детском саду
t1.clear();
t2.clear();
founded=false;
for(unsigned i=0; i
t=toys[i].id;
for(unsigned j=0; j
for(unsigned k=0; k
if(t==houses[j].toylist[k])
founded = true;
}
if(!founded) t1.push_back(t);
founded = false;
}
unsigned h=houses.size();
if(t1.size()==h)
t2.push_back(t);
t1.clear();
}
cout <<"Игрушки, которых нет ни в одном детском саду:" <
cout <
return 0;
}
Тестовый прогон:
1-я игрушка: Барабан
Добавить ещё одну игрушку? (y/n): y
2-я игрушка: Кукла Барби
Добавить ещё одну игрушку? (y/n): y
3-я игрушка: Вертолет
Добавить ещё одну игрушку? (y/n): y
4-я игрушка: Конструктор
Добавить ещё одну игрушку? (y/n): y
5-я игрушка: Железная дорога
Добавить ещё одну игрушку? (y/n): y
6-я игрушка: Флейта
Добавить ещё одну игрушку? (y/n): y
7-я игрушка: Слон
Добавить ещё одну игрушку? (y/n): y
8-я игрушка: Самосвал
Добавить ещё одну игрушку? (y/n): y
9-я игрушка: Кран
Добавить ещё одну игрушку? (y/n): y
10-я игрушка: Пожарная машина
Добавить ещё одну игрушку? (y/n): n
Игрушка 1 - Барабан
Игрушка 2 - Кукла Барби
Игрушка 3 - Вертолет
Игрушка 4 - Конструктор
Игрушка 5 - Железная дорога
Игрушка 6 - Флейта
Игрушка 7 - Слон
Игрушка 8 - Самосвал
Игрушка 9 - Кран
Игрушка 10 - Пожарная машина
1-й детский сад. Введите номера игрушек:
1
Добавить еще? (y/n): y
2
Добавить еще? (y/n): y
3
Добавить еще? (y/n): y
4
Добавить еще? (y/n): y
5
Добавить еще? (y/n): n
Добавить ещё детский сад? (y/n): y
2-й детский сад. Введите номера игрушек:
2
Добавить еще? (y/n): y
3
Добавить еще? (y/n): y
4
Добавить еще? (y/n): n
Добавить ещё детский сад? (y/n): y
3-й детский сад. Введите номера игрушек:
1
Добавить еще? (y/n): y
2
Добавить еще? (y/n): y
4
Добавить еще? (y/n): y
5
Добавить еще? (y/n): n
Добавить ещё детский сад? (y/n): y
4-й детский сад. Введите номера игрушек:
2
Добавить еще? (y/n): y
3
Добавить еще? (y/n): y
4
Добавить еще? (y/n): y
5
Добавить еще? (y/n): y
1
Добавить еще? (y/n): y
6
Добавить еще? (y/n): n
Добавить ещё детский сад? (y/n): n
Детсад √1 - игрушки: 1 2 3 4 5
Детсад √2 - игрушки: 2 3 4
Детсад √3 - игрушки: 1 2 4 5
Детсад √4 - игрушки: 2 3 4 5 1 6
Игрушки, которые есть во всех детских садах:
2 (Кукла Барби), 4 (Конструктор),
Игрушки, которых нет ни в одном детском саду:
7 (Слон), 8 (Самосвал), 9 (Кран), 10 (Пожарная машина),
Для закрытия данного окна нажмите <ВВОД>...