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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
Temoffey
20 / 40 / 0
Регистрация: 21.11.2010
Сообщений: 96
#1

Эйлеров цикл - C++

11.11.2011, 22:56. Просмотров 1360. Ответов 1
Метки нет (Все метки)

Есть программа:
Код
def euler_circuit(G):
    EP=[]  # Эйлеров цикл - массив вершин.
 
    #возвращает локальный замкнутый цикл    
    def euler(v):
        cycle={}
        while (G.degree(v)>0):  #пока не оказались в "безвыходной" вершине
            w=G.neighbors(v)[0] # берем $w$ --- первого попавшегося "соседа" $v$ 
            cycle[v]=w          # записываем ребро $(v,w)$ в $cycle$ и стираем его из графа
            G.delete_edge(v,w)
            v=w                 # повторяем все с вершиной $w$
        return cycle    
 
    # добавляет цикл к эйлерову пути
    def add_cycle():        
        print EP,"+",
        if len(EP)>0: # ищем вершину, к которой можно добавить цикл
            for i in range(0,len(EP)):
                if G.degree(EP[i])>0:
                    v=EP[i]
                    break
        else: # Подготавливаем пока пустой EP к присоединению цикла 
            v=G.nodes()[0] # выбираем первую попавшуюся вершину
            EP.append(v)   # и добавляем ее в EP
            i=0    
        c=euler(v)
        print c,"-->",    
        while c: # пока не перенесли все содержимое цикла   
            i=i+1; EP.insert(i,c[v]) #вставляем очередную вершину в EP        
            w=c[v] #переходим к следующей
            del c[v] #удаляя из цикла вставленную.
            v=w
        print EP
 
 
    #Проверка, необходимых и достаточных условий существования
    for v in G.nodes(): 
        if (G.degree(v) % 2)<>0: print "No Euler path!"; return
 
    while (G.number_of_edges()>0):
        add_cycle()          # добавляем цикл к эйлерову пути
 
    print EP
    return EP
Поясните плз в каком она компиляторе сделается и если можно переведите её в Си если не сложно.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.11.2011, 22:56     Эйлеров цикл
Посмотрите здесь:

Эйлеров путь - C++
Я примерно написал програму, но мой вариант работает долго - 28(иногда меньше, иногда больше) минут.Подскажите пожалуйста есть ли какой-то...

Существует ли Эйлеров цикл? - Дискретная математика
Существует ли Эйлеров цикл, если ровно две вершины имеют нечётную степень? Граф ненаправленный.

Эйлеров цикл и цепь - Дискретная математика
1) Найти эйлеров граф и указать в нем эйлеров цикл (нумерацией ребер) Вроде как первый, т.к. степени вершин четные. Но цикл не могу...

Эйлеров цикл: нужен готовый пример - C#
Ниукого не завалялся готовый поиск Эйлеревого цикла (это тот который проверяет можно ли в ориентированном графе пройтись по всем вершинам и...

Эйлеров граф - Дискретная математика
приветствую, подскажите пожалуйста, как доказать что нельзя нарисовать эйлеров граф с нечетным количеством вершин и четным количеством...

Гамильтонов, но не Эйлеров - Дискретная математика
Приведите, пожалуйста пример эйлерового графа, который не является гамильтоновым.

Эйлеров интеграл - Математический анализ
\int_{0}^{a} x^2 * \sqrt{a^2-x^2} dx C Помощью эйлеровых интегралов вычислить.

Эйлеров интеграл - Математический анализ
Не могу понять, как решаются подобные интегралы, какие магические замены сделать?? \int_{0}^{\infty}\frac{x^3}{(1+x)^6}dx

Эйлеров интеграл - Математический анализ
Решаю Ейлеревые интегралы. Уже во втором примере подряд вылезает постоянно логарифм. Делаю куча замен, но никак не получается. Помогите...

Эйлеров путь на графах - Lisp
Здравствуйте! Напишите, пожалуйста, программу, определяющую эйлеровый эйлеров путь, начинающийся с заданной вершины...

Выразить через эйлеров интеграл - Математический анализ
Выразить через эйлеров интеграл \int_{0}^{pi/2} sin^m (x) * cos^n (x) dx

Эйлеров граф и проверка матрицы инцидентности - C#
Ребята, нужна помощь. Завтра сдавать программу, а доделать не знаю как. В общем программа из файла считывает матрицу инцидентности,...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
talis
791 / 543 / 37
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
11.11.2011, 23:03     Эйлеров цикл #2
Temoffey, выглядит как бейсик или пайтон.
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru