С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

Нужно оптимизировать код - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Странная ошыбка http://www.cyberforum.ru/cpp-beginners/thread968246.html
Всём привет Есть такая проблема: при использовании qsort(&c, c.size(), sizeof(int), compare) Кидает ексепшен, почёму понять не могу. Вот весь код: #include <iostream> #include <vector> int...
C++ Работа со структурой данных, чтение/сохранение во внешний файл помогите разобраться с задачкой!! {Написать программу, представляющую собой простейшую систему для управления данными. Исходные данные для программы хранятся в текстовом файле в виде строк. Для... http://www.cyberforum.ru/cpp-beginners/thread968244.html
В числе зачеркнули первую справа цифру и приписали ее слева - вывести полученное число C++
#include <iostream> #include <stdio.h> #include <math.h> #include <conio.h> int main(int argc, char** argv) { float d,c; int b,a; printf ("vvedite trhznachnoe chislo ");
что тут делать ? C++
Наведите объявления переменных в цикле, который увеличивает переменную с именем totalDartsInCircle если Расположение дротик находится в пределах радиуса круга. Вы будете нужно использовать формулы...
C++ Чтение файла построчно http://www.cyberforum.ru/cpp-beginners/thread968232.html
Требуется занести в массивы строчки. В каждый массив своя строчка. Для этого решил использовать массив объектов. #include<iostream> #include<fstream> using namespace std; const int def = 10000;...
C++ Произвести следующую обработку 15 вещественных чисел Произвести следующую обработку 15 вещественных чисел: найти среднее арифметическое отрицательных чисел и подсчитать количество чисел, входящих в диапазон .(без использования массива; с помощью... подробнее

Показать сообщение отдельно
BabyGluk
26 / 26 / 4
Регистрация: 10.04.2013
Сообщений: 167

Нужно оптимизировать код - C++

03.10.2013, 18:12. Просмотров 1045. Ответов 16
Метки (Все метки)

Вобщем код не принемает сайт, немного нагружает и по времени не проходит

задание
Кликните здесь для просмотра всего текста
Август и Беатриса играют в игру. Август загадал натуральное число от 1 до n. Беатриса пытается угадать это число, для этого она называет некоторые множества натуральных чисел. Август отвечает Беатрисе YES, если среди названных ей чисел есть задуманное или NO в противном случае. После нескольких заданныъх вопросов Беатриса запуталась в том, какие вопросы она задавала и какие ответы получила и просит вас помочь ей определить, какие числа мог задумать Август.

Первая строка входных данных содержит число n — наибольшее число, которое мог загадать Август. Далее идут строки, содержащие вопросы Беатрисы. Каждая строка представляет собой набор чисел, разделенных пробелами. После каждой строки с вопросом идет ответ Августа: YES или NO.

Наконец, последняя строка входных данных содержит одно слово HELP. Вы должны вывести (через пробел, в порядке возрастания) все числа, которые мог задумать Август.


вход
Кликните здесь для просмотра всего текста
10
1 2 3 4 5
YES
2 4 6 8 10
NO
HELP

выход
Кликните здесь для просмотра всего текста
1 3 5


мой код
Кликните здесь для просмотра всего текста
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
60
61
62
63
64
65
66
67
68
69
#include<iostream>
#include<set>
#include<string>
#include <sstream>     
#include <algorithm>   
#include<vector>
using namespace std;
int main(int argc, char* argv[])
{
    set<int> main,tmp,yes,no;
    
    int max;
 
    string str;
    cin>>max;
 
    for(int i = 1; i<=max;i++)
        yes.insert(i);
 
    while(str!="HELP"){
        cin>>str;
        istringstream iss (str);
        for(int i = 0;i<str.size();i++)
        {
            int x;
            iss>>x;
            if (x <= max)
                tmp.insert(x);
        }
        if (str == "YES")
        {
            vector<int> v(max,0);  
        vector<int>::iterator it;
        it = set_intersection(yes.begin(),yes.end(), tmp.begin(), tmp.end(), v.begin());
    v.resize(it-v.begin());
 
    
            yes.clear();
            for(it = v.begin();it != v.end();it++)
                yes.insert(*it);
            tmp.clear();
        }
        if (str =="NO"){
             
            vector<int> v(max,0);  
        vector<int>::iterator it;
        it = set_union(no.begin(),no.end(), tmp.begin(), tmp.end(), v.begin());
    v.resize(it-v.begin());
 
    
            no.clear();
            for(it = v.begin();it != v.end();it++)
                no.insert(*it);
            tmp.clear();
        }
 
        
    
    }
 vector<int> v(max,0);  
  std::vector<int>::iterator it;
    it = set_difference (yes.begin(),yes.end(), no.begin(), no.end(), v.begin());
    v.resize(it-v.begin());
    for(it = v.begin();it != v.end();it++)
        cout<<*it<<" ";
        cout<<endl;
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.