К основному контенту

Интересная задачка для развития. Решено через Map. C++

Три дачника выращивают на своих участках цветы из имеющегося списка (ирис,
роза, астра, пион, георгин, хризантема, гладиолус).Определить, цветы каких
видов выращивают все дачники; хотя бы два из них; не выращивает ни один
из дачников.


#include "stdafx.h"
#include <iostream>
#include <map>
#include <string>
using namespace std;

void main()
{
bool flag;
map <string, int> flovers;
flovers["Iris"] = 0;
flovers["Rose"] = 0;
flovers["Astra"] = 0;
flovers["Pion"] = 0;
flovers["Georgin"] = 0;
flovers["Khrizantema"] = 0;
flovers["Gladoilus"] = 0;
for (int i = 0; i < 3; i++)
{
cout << i + 1 << " cottager grows:" <<  endl << "NO - 0" << endl << "YES - 1 " << endl << "********************" << endl;
for (map<string, int>::iterator it = flovers.begin(); it != flovers.end(); ++it)
{
cout << (*it).first << " = ";
try 
{
if (!(cin >> flag)) 
throw "ERROR!\nYou can not enter characters. Please, enter 0 or 1";
}
catch (char *str_exception)
{
cout << str_exception << endl;
exit(1);
}
if (flag)
(*it).second++;
}
}
cout << endl << "Grows all cottager: ";
for (map<string, int>::iterator it = flovers.begin(); it != flovers.end(); ++it)
{
if ((*it).second == 3)
cout << (*it).first << ", ";
}
cout << endl << "Grown at least two cottagers: ";
for (map<string, int>::iterator it = flovers.begin(); it != flovers.end(); ++it)
{
if (((*it).second == 2) || ((*it).second == 3))
cout << (*it).first << ", ";
}
cout << endl << "No one from the growing: ";
for (map<string, int>::iterator it = flovers.begin(); it != flovers.end(); ++it)
{
if ((*it).second == 0)
cout << (*it).first << ", ";
}
cout << endl;
}

Комментарии

Популярные сообщения из этого блога

ВОПРОС К ЧИТАТЕЛЯМ

Уважаемые читатели моего блога и просто проходящие мимо! У меня появилась идея заняться созданием уроков по интересующим вас темам. Предпочтительно на C++, но не ограничиваясь ими, я хочу поделиться своими знаниями не только в виде готового кода но и подробными объяснениями что к чему. Прошу вас, если вы имеете идею и хотели бы разобраться в какой-то теме - отпишитесь в комментариях, что было бы вам интересно. Постараюсь помочь. 

7 глава, Лафоре Р

*1. Напишите функцию reversit(), которая переворачивает строку (массив типа char). Используйте цикл for, который меняет местами первый и последний символы, затем следующие и т. д. до предпоследнего. Строка должна пере- даваться в функцию reversit() как аргумент. Напишите программу для выполнения функции reversit(). Программа долж- на принимать строку от пользователя, вызывать функцию reversit(), а за- тем выводить полученный результат. Используйте метод ввода, который позволяет использовать внутренние пробелы. Протестируйте программу на примере фразы «Аргентина манит негра».

6 глава, Лафоре Р

*1. Создайте класс Int, имитирующий стандартный тип int. Единственное поле этого класса должно иметь тип int. Создайте методы, которые будут устанавливать значение поля, равным нулю, инициализировать его целым значением, выводить значение поля на экран и складывать два значения типа Int. Напишите программу, в которой будут созданы три объекта класса Int, два из которых будут инициализированы. Сложите два инициализирован- ных объекта, присвойте результат третьему, а затем отобразите результат на экране.