Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 287

Оптимизация алгоритма, отсеивающего одинаковые циклы (начавшиеся с разных точек)

11.08.2021, 21:23. Показов 1148. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Я написал функцию, которая удаляет из списка циклов циклы (циклы записаны без повторения начальной точки) одинаковые. Одинаковыми я называю те, что содержат только одинаковые точки. Например, АБСД и СДАБ - одинаковые. (Я не дочитал книгу по графам, поэтому общепринятой терминологии ещё не знаю).
Но делаю я это "в лоб". (См код)
Python
1
2
3
4
5
6
7
8
9
10
def DeleteIdenticalCycles(cycles):
  test_cycles = []
  while test_cycles != cycles:
    test_cycles = cycles.copy()
    for i in cycles:
      for a in cycles:
        if i != a and set(i) == set(a):
          cycles.remove(i)
          break
  return cycles
Мне кажется, что данную задачу можно было бы решить эффективней, но я не придумал как. Можете, пожалуйста, объяснить мне, как нормально удалить лишние циклы.
П.С. Буду благодарен, если кто-нибудь объяснит, как правильней записать данный алгоритм (очень мне не нравится копирование списка, чтобы проверять, изменился ли список).
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.08.2021, 21:23
Ответы с готовыми решениями:

Циклы обработки сообщений разных форм в разных потоках
Здравствуйте! Подскажите как реализовать циклы обработки сообщений разных форм в разных потоках. У коде одной формы сделал так: ...

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

Оптимизация алгоритма
Условие задачи: Лесенкой называется набор кубиков, в котором каждый более верхний слой содержит кубиков меньше, чем предыдущий. Требуется...

3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
12.08.2021, 06:49
Мне кажется, что до того, как оптимизировать код, стоит подумать о критерии совпадения циклов. Если сравнивать множества вершин, то то вот эти два цикла ['A','B','C','D'] и ['A','C','D','B'] будут одинаковы. Но в действительности это разные циклы.

А решить задачу удаления циклов с одинаковым набором вершин можно, например, так:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
from copy import copy
 
def setOfCycles(cycles):
    tmp=copy(cycles)
    n=len(tmp)
    for i in range(n-1):
        si=set(tmp[i])
        for j in range(i+1,n):
            if si==set(tmp[j]):
                tmp[j]=[]
    return [a for a in tmp if len(a)>0]    
    
print(setOfCycles([['a','b','c'],['a','b','d'],['a','c','b'],['b','c','d']]))
1
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,760
12.08.2021, 07:59
Сравнивать только множества вершин для проверки тождественности циклических графов некорректно, т.к. граф это упорядоченная структура.
Я бы сделал такую функцию сравнения циклов:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
def test(g1,g2):
    if g1[0] in g2:
        idx=g2.index(g1[0])
        res= g1[1:]==g2[idx+1:]+g2[:idx] or g1[:0:-1]==g2[idx+1:]+g2[:idx]
        return res
    return False
 
g1=['A','B','C','D']
g2=['C','D','A','B']
print(test(g1, g2)) # True
g2=['C','D','B','A']
print(test(g1, g2)) #False
g2=['A','D','C','B']
print(test(g1, g2)) # True
P.S. для орграфов надо убрать or и до конца строки
1
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 287
12.08.2021, 18:32  [ТС]
Catstail, я забыл упомянуть, что работаю с простыми циклами. Мне кажется, что на графе нельзя получить два разных простых цикла, которые бы содержали только одинаковые точки.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.08.2021, 18:32
Помогаю со студенческими работами здесь

Оптимизация алгоритма
День добрый, хочу обратится за советом. Имею следующее. Получаю данные в 4-ре List<double> (как не важно). signal_input1(2,3,4)....

Оптимизация алгоритма
Здравствуйте, решаю следующую задачу: Задан граф с K вершинами и отметками на ребрах – целыми числами от 1 до K. В базе данных хранится N...

Оптимизация алгоритма
Вот задачка: вот мой код: #include <iostream> #include <string> #include <vector> #include <ctime> using namespace std; ...

Оптимизация алгоритма
Помогите оптимизировать и ускорить алгоритм. В задаче Петя и Ваня в камни играют с 2 кучами. За один ход игрок может добавить в одну...

Оптимизация алгоритма
Всем привет. Если кто-то сможет оптимизировать "это", то я отблагодарю его материально. uint32_t a0 = ps*26 + ps*51 + ps*102 + ps*51 +...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 27.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 27.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 27.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 25.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 25.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru