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

Оптимизировать перебор - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как объяснить какую книгу выбрать в подарок? http://www.cyberforum.ru/cpp-beginners/thread711501.html
Девушка подарит мне книгу по программированию C++. Меня интересует книга для новичков, но чтобы не консольный си был а объектно-ориентированный (ну то есть формы, окошки). Подскажите как можно...
C++ Выделить первое слово из строки(работа с указателями) Здравствуйте, помогите пожалуйста, в чем ошибка в моем коде: #include <iostream> #include <stdio.h> #include <string.h> using namespace std; int substr(char *s1, char *s2); http://www.cyberforum.ru/cpp-beginners/thread711496.html
Написать программу: копирование файлов C++
Пожалуйста, помогите написать программу, копирующую один файл в другой. Имена файлов программа должна получать из командной строки.Если не удаётся открыть соответствующий файл, должно выдаваться...
Сколько букв "У" в введенном слове стоит на четных местах? C++
сортировка строк в С++
C++ Не могу понять, как исправить ошибку в при вызове методов класса http://www.cyberforum.ru/cpp-beginners/thread711476.html
Не могу понять, как испровить ошибку в при вызове методов классa: #include <cstdlib> #include <iostream> using namespace std; class orenda_kvartiri { public:
C++ Передача объекта структуры по ссылке Здравствуйте. Нужно использовать передачу структуры по ссылке(или по указателю). Объясните пожалуйста как это делать и , если можно, как это можно безболезненно запихать в мой код #include... подробнее

Показать сообщение отдельно
Bringoff
СуперМодулятор
132 / 131 / 15
Регистрация: 03.11.2012
Сообщений: 974

Оптимизировать перебор - C++

27.11.2012, 23:22. Просмотров 421. Ответов 2
Метки (Все метки)

Неделю учу С++, так что прошу не гадить. Надо уменьшить время работы.
Задача:
Кликните здесь для просмотра всего текста
Вступление
— Брат мой, Магистр Ордена хочет узнать завтра о результатах наших многолетних изысканий. Он хочет видеть, ни много, ни мало, Суммирующую Машину! Даже более того: он хочет, чтобы наша Машина — всего лишь машина — продемонстрировала свое постижение Таинства Суммы настолько глубоко, насколько это возможно. Он хочет, чтобы Машина нашла каких-нибудь два числа, дающих в сумме священное число 10000!
— Тс-с-с! Но это же безумство, граничащее с кощунством! Как Машина может ВЫЧИСЛИТЬ священное число? Двадцать семь лет мы работаем над ней, и смогли только лишь научить ее отвечать на вопрос: «Больше сумма двух введенных чисел, чем 10000, или меньше?». Но разве может смертный найти два таких числа, чтобы их сумма оказалась равна 10000?
— И все же нам придется сделать это с помощью нашей Машины, пусть она и неспособна на это. Иначе у нас будут… ну, скажем так, крупные неприятности, если кипящее масло можно назвать таким словом. Впрочем, у меня есть идея. Помнишь, на той неделе мы ввели в Машину числа −7 и 13, она ответила, что их Сумма меньше 10000. Я не знаю, как это проверить, но нам ничего не остается, как доверять созданию наших рук. Что, если теперь мы возьмем число большее, чем −7 и снова запустим Машину? И будем так делать снова и снова, пока не найдем такое число, которое в сумме с 13 даст 10000! Надо только подготовить список возрастающих чисел.
— Не верю я в эту идею… Давай лучше начнем с суммы, заведомо большей, чем Священное число и будем уменьшать одно из слагаемых, так у нас больше шансов избегнуть кипяще… крупных неприятностей.
Так ни о чём и не договорившись, Братья разошлись по своим кельям. К следующему дню, каждый из них подготовил такой список чисел, который, по его мнению, мог бы их спасти… Смогут ли спасти их оба списка вместе?
Задача
Ваша программа должна определять, можно ли из двух списков целых чисел выбрать по одному числу так, чтобы в сумме они составили 10000.
Исходные данные
Состоят из двух списков — одного, потом другого. Формат каждого из этих списков таков: в первой строчке записано количество Ni чисел в i-м списке, далее в Ni строчках по одному числу в строке записаны сами списки. Выполняются неравенства 1 ≤ Ni ≤ 50000, все элементы списков лежат в диапазоне от –32768 до 32767. Первый список упорядочен по возрастанию, второй — по убыванию.
Результат
На выходе следует записать YES, если из списков можно выбрать по числу, которые в сумме дадут 10000 и NO в противном случае.

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
#include <iostream>
using namespace std;
 int main()
  {
        int nfirst,i;
        int first[50000];
        cin>>nfirst;
        
        for (i=1;i<=nfirst;i++)
        {
            cin>>first[i];
        }
        int nsecond;
        cin>>nsecond;
        i=1;
        int second[50000];
        for (i=1;i<=nsecond;i++)
        {
            cin>>second[i];
        }   
        int j=1;
        bool f;
        f=false;
        for (i=1;i<=nfirst;i++)
        {
            for (j=1;j<=nsecond;j++)
            {
                if (first[i]+second[j]==10000)
                {
                    f=true;
                    break;
                }
                if (f) break; 
            }
        }
        if (f)
            cout<<"YES";
            else cout<<"NO";
         return 0;   
        }
Выходит за предел времени. На паскале на 4-ом тесте, тут на 10-ом. Лимит - 1 секунда.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru