Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
0 / 0 / 0
Регистрация: 13.06.2020
Сообщений: 3

Не проходит ограничение по времени или как доработать код

04.11.2020, 13:21. Показов 1725. Ответов 4

Студворк — интернет-сервис помощи студентам
В данной задачи на определение неориентированности графа, на 15 тесте не проходит ограничение по времени в 1000 мс.

https://codeforces.com/edu/cou... /problem/A

Вот код, в чем проблема предположить не могу
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
#include <iostream>
#include <algorithm>
#include <iomanip>
#include <cmath>
#include <vector>
#include <string>
using namespace std;
bool proverka_par(int g[][2], int temp[][2], int kolvo) {
    bool ans = false;
    for (int z = 0; z < kolvo; ++z) {
        for (int x = 0; x < 2; ++x) {
            int a = temp[z][0];
            int b = temp[z][1];
            g[z][0] = 0; g[z][1] = 0;
            for (int i = 0; i < kolvo; ++i) {
                for (int j = 0; j < 2; ++j) {
                    if (((a == g[i][0]) && (b == g[i][1])) || a == b) {
                        ans = true; break;
                    }
                    swap(a, b);
                }
                if (ans) break;
            }
            if (ans) break;
            g[z][0] = a; g[z][1] = b;
        }
        if (ans) break;
    }
    return ans;
}
int main() {
    int t, n, m;
    cin >> t;
    for (int i = 0; i < t; ++i) {
        string temp;
        getline(cin, temp);
        cin >> n >> m;
        int g[100000][2];
        if (m == 0) cout << "YES" << endl;
        else {
            bool notor = false;
            for (int i = 0; i < m; ++i) {
                for (int j = 0; j < 2; ++j) {
                    cin >> g[i][j];
                }
            }
            for (int i = 0; i < m; ++i) {
                for (int j = 0; j < 2; ++j) {
                    if (proverka_par(g, g, m)) {
                        notor = true; break;
                    }
                }
            }
            if (notor && m != 1) cout << "NO" << endl;
            else cout << "YES" << endl;
        }
    }
}
На поиски решения было потрачено более 5 часов.
Помогите, пожалуйста, оптимизировать или же доработать код.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.11.2020, 13:21
Ответы с готовыми решениями:

Как можно ускорить код? Решение выдаёт верное, но по времени не проходит
Как можно ускорить код? Решение выдаёт верное, но по времени не проходит ограничение по времени на тест 2 секунды ограничение по...

Как можно доработать код так, чтобы к каждому времени года был месяц и к нему ассоциации...
Как можно доработать этот код что бы к каждому времени года был месяц и к нему ассоциации которые пользователь будет вводить и будет...

Самое частое слово (код не проходит по времени)
Задача: Дан текст. Выведите слово, которое в этом тексте встречается чаще всего. Если таких слов несколько, выведите то, которое меньше в...

4
264 / 183 / 87
Регистрация: 03.05.2020
Сообщений: 790
04.11.2020, 13:38
задание выложите, или прикажете регистрироваться?
0
Параллельный Кот
 Аватар для valen10
1905 / 827 / 350
Регистрация: 25.03.2016
Сообщений: 2,045
04.11.2020, 13:45
Задачу сюда перепишите. Ходить по левым ссылкам, и тем более там регистрироваться, нет желания.

Задача решается за линейное время без сохранения входных данных. Судя по коду, у Вас получилась сложность https://www.cyberforum.ru/cgi-bin/latex.cgi?O(n^3). Оптимизировать следует не код, а алгоритм. Опишите свой способ решения, зачем здесь такое количество вложенных циклов?

Добавлено через 6 минут
Достаточно по списку смежнтсти построить матрицу смежности и проверить симметричность относительно главной диагонали.
0
0 / 0 / 0
Регистрация: 13.06.2020
Сообщений: 3
04.11.2020, 14:12  [ТС]
Извиняюсь
Миниатюры
Не проходит ограничение по времени или как доработать код  
0
0 / 0 / 0
Регистрация: 13.06.2020
Сообщений: 3
04.11.2020, 14:20  [ТС]
Я создаю два одинаковых двумерных массива, беру пару из первого, записываю ее в переменные, стираю их во втором массиве и проверяю их наличие, если они не найдены, я меняю переменные местами и повторяю поиск, при нахождении соответствия условию, обрываю циклы если все же нет совпадений, то восстанавливаю элементы из переменных, и иду по массиву далее.

Добавлено через 1 минуту
Вам задано два числа n и m и список из m пар целых чисел (каждое число в паре от 1 до n). Проверьте, что заданный список пар является корректным набором ребер некоторого неориентированного графа (в графе не должно быть петель и кратных ребер).

Входные данные
В первой строке находится целое число t (1≤t≤10^5) — количество наборов входных данных в тесте. Далее следуют t наборов входных данных. Перед каждым набором входных в тесте записана пустая строка.

В первой строке каждого набора тестовых данных записаны два целых числа n и m (1≤n≤10^5,0≤m≤10^5) — ограничения на числа в парах и количество пар соответственно.

В каждой из следующих m строк записана пара целых чисел u и v (1≤u,v≤n).

Суммы n и m по всем наборам тестовых данных не превосходят 10^5.

Выходные данные
Для каждого набора тестовых данных в отдельной строке выведите:

«YES» — если заданный список пар является корректным набором ребер некоторого неориентированного графа (полученный граф не имеет петель и кратных ребер);
«NO» — в противном случае.

Добавлено через 2 минуты
Цитата Сообщение от valen10 Посмотреть сообщение
Достаточно по списку смежнтсти построить матрицу смежности и проверить симметричность
относительно главной диагонали.
Не подскажете, как построить матрицу смежности?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.11.2020, 14:20
Помогаю со студенческими работами здесь

Не проходит по времени. Надо написать код который будет работать меньше за o(n^2). Что делать?
Национальный парк штата Q недавно приобрел прекрасную березовую аллею, состоящую из n деревьев. Каждое дерево имеет высоту Hi. ...

Программа не проходит тесты по времени, посоветуйте как исправить
Добрый день, не могли бы вы подсказать по задаче. Имеется круг с целыми числами от 1 до n. Числа можно или занимать или освобождать если...

Подскажите как доработать отсчет времени до Нового Года
Все привет! Есть отсчет времени до нового года. &lt;script&gt; var now = new Date(); var ny = Math.floor(now.getTime() /...

Как сделать ограничение по времени для вычисления?
Здравствуйте, помогите, пожалуйста. Возможно ли сделать ограничение по времени для вычисления здесь: true_symbols = ('0', '1',...

Как преодолеть ограничение времени на обращение к wcf - сервису
Уважаемые Гуру! Обращаюсь к wcf (ria) сервису. Если время отсутствия ответа превышает примерно минуту, то получаю сообщение, что...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 01.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 31.01.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru