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

"Куча Орехов"

14.12.2011, 20:14. Показов 1229. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
http://acm.timus.ru/problem.aspx?space=1&num=1644
Десять больших грецких орехов — это, конечно, целая куча! А два ореха — совсем мало, ни о какой куче здесь не может идти и речи. А как насчёт шести орехов? Много это или мало? Попугай между тем уже давно ответил для себя на этот вопрос: «Мало — это когда всё съел и ещё хочется, а куча — это когда больше уже не хочется.» Попугай любит покушать, но не любит переедать. Поэтому он решил узнать минимальное количество орехов, которого ему хватит для того, чтобы насытиться.
С этой целью он провёл серию экспериментов. Каждый эксперимент заключался в следующем: изрядно проголодавшись, Попугай в один присест съедал некоторое количество орехов и записывал, наелся ли он этим количеством. Конечно, если Попугай наелся некоторым количеством орехов, то он должен наесться и любым бОльшим количеством. И наоборот, если он остался голодным, съев несколько орехов, то он должен остаться голодным, съев и любое меньшее количество орехов. Помогите Попугаю обработать полученные результаты.

Исходные данные
В первой строке записано целое число n — количество экспериментов, проведённых Попугаем (0 ≤ n ≤ 100). Каждая из следующих n строк содержит описание очередного эксперимента — количество орехов, съеденных Попугаем (целое число от 3 до 9), и через пробел слово «hungry» или «satisfied», указывающее, остался ли Попугай голодным или наелся, соответственно. Известно, что Попугай заведомо наестся десятью орехами и заведомо останется голодным, съев лишь два.

Результат
Выведите минимальное количество орехов, которое должен съесть Попугай, чтобы гарантированно не остаться голодным. Если же записи Попугая противоречивы, выведите «Inconsistent».
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
#include <iostream>
#include <string>
using namespace std;
int main()
{
int hun[100],sat[100],N,maxhun=0,minsat=0;
cin>>N;
int numhun=0,numsat=0;
for(int i=0;i<N;i++)
{
int temp;
string lol;
cin>>temp>>lol;
if(lol=="hungry")
{
hun[numhun]=temp;
++numhun;
}
else
{
sat[numsat]=temp;
++numsat;
}
}
for(int i=1;i<numhun;i++)
    if(hun[i]>hun[maxhun])
        maxhun=i;
for(int i=1;i<numsat;i++)
    if(sat[i]<sat[minsat])
        minsat=i;
if(numsat==0 || N==0)
    cout<<10;
else
    if(hun[maxhun]>=sat[minsat])
        cout<<"Inconsistent";
else
    cout<<sat[minsat];
}
Почему не проходит все тесты?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.12.2011, 20:14
Ответы с готовыми решениями:

Стек и куча
Вроде разобрался с этими зверями, хочется уточнить некоторые моменты на понимание: физически они в ОЗУ, сначала сегмент кода программы,...

Куча вопросов..
В связи с последовательным изучением С++ и с параллельным при этом отсутствием рабочего подключения к Интернету у меня накопилась куча...

биномиальная куча
подкиньте какой литературы или пример формирования и редактирования биномиальной кучи, буду очень благодарен

3
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
14.12.2011, 20:48
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
/////////////////////////////////////////////////////////////////////////////////////////
//Десять больших грецких орехов — это, конечно, целая куча! А два ореха — совсем мало, 
//ни о какой куче здесь не может идти и речи. А как насчёт шести орехов? Много это или мало? 
//Попугай между тем уже давно ответил для себя на этот вопрос: «Мало — это когда всё съел 
//и ещё хочется, а куча — это когда больше уже не хочется.» Попугай любит покушать, но 
//не любит переедать. Поэтому он решил узнать минимальное количество орехов, которого ему 
//хватит для того, чтобы насытиться.
//С этой целью он провёл серию экспериментов. Каждый эксперимент заключался в следующем: 
//изрядно проголодавшись, Попугай в один присест съедал некоторое количество орехов 
//и записывал, наелся ли он этим количеством. Конечно, если Попугай наелся некоторым 
//количеством орехов, то он должен наесться и любым бОльшим количеством. И наоборот, 
//если он остался голодным, съев несколько орехов, то он должен остаться голодным, съев 
//и любое меньшее количество орехов. Помогите Попугаю обработать полученные результаты.
//
//Исходные данные
//В первой строке записано целое число n — количество экспериментов, проведённых Попугаем 
//(0 ≤ n ≤ 100). Каждая из следующих n строк содержит описание очередного эксперимента — 
//количество орехов, съеденных Попугаем (целое число от 3 до 9), и через пробел слово «hungry» 
//или «satisfied», указывающее, остался ли Попугай голодным или наелся, соответственно. 
//Известно, что Попугай заведомо наестся десятью орехами и заведомо останется голодным, 
//съев лишь два.
//
//Результат
//Выведите минимальное количество орехов, которое должен съесть Попугай, чтобы гарантированно 
//не остаться голодным. Если же записи Попугая противоречивы, выведите «Inconsistent».
/////////////////////////////////////////////////////////////////////////////////////////
#include <iostream>
#include <set>
#include <string>
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::set<int>   T_result_set;
typedef std::string     T_str;
/////////////////////////////////////////////////////////////////////////////////////////
int main()
{
    int             N = 0;
    std::cin >> N;
    int             n = 0;
    T_str           res;
    T_result_set    hungry_set;
    T_result_set    satisfied_set;
    for(int  i = 0; i < N; ++i)
    {
        std::cin >> n;
        std::cin >> res;
 
        (res == "hungry" ? hungry_set : satisfied_set).insert(n);
    }
 
    if( *hungry_set.rbegin() < *satisfied_set.begin() )
    {
        std::cout << *satisfied_set.begin();
    }
    else
    {
        std::cout << "Inconsistent";
    }
    std::cout << std::endl;
}
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
15.12.2011, 04:16
Цитата Сообщение от Hi4ko Посмотреть сообщение
if(hun[maxhun]>=sat[minsat])
cout<<"Inconsistent";
заменить на:
C++
1
2
if(numhun>0 && hun[maxhun]>=sat[minsat])
        cout<<"Inconsistent";
1
74 / 74 / 13
Регистрация: 21.10.2010
Сообщений: 376
15.12.2011, 20:41  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
заменить на:
C++
1
2
if(numhun>0 && hun[maxhun]>=sat[minsat])
        cout<<"Inconsistent";
истерика у меня
спасибо тебе)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.12.2011, 20:41
Помогаю со студенческими работами здесь

Повреждена куча
Запускаю - если ввожу любое число больше 2х, то все работает. Но если пишу количество: 2, программа не воспроизводит результат. И пишет,...

Куча в DLL и EXE
Что-то не понимаю - почему куча exe и dll разная, ведь адресное пространство процесса одно?

Куча непонятных ошибок
Вот код: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt; int main() { std::ifstream ifs(&quot;test.txt&quot;,...

Что такое куча
new (C++) Материал из Википедии — свободной энциклопедии new — оператор языка программирования C++, обеспечивающий выделение...

что такое КУЧА?
что такое КУЧА?


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru