SDUT-3364_歐拉回路

數據結構實驗之圖論八:歐拉回路

Time Limit: 1000 ms Memory Limit: 65536 KiB

Problem Description

在哥尼斯堡的一個公園里,有七座橋將普雷格爾河中兩個島及島與河岸連接起來。

能否走過這樣的七座橋,并且每橋只走一次?瑞士數學家歐拉最終解決了這個問題并由此創立了拓撲學。歐拉通過對七橋問題的研究,不僅圓滿地回答了哥尼斯堡七橋問題,并證明了更為廣泛的有關一筆畫的三條結論,人們通常稱之為歐拉定理。對于一個連通圖,通常把從某結點出發一筆畫成所經過的路線叫做歐拉路。人們又通常把一筆畫成回到出發點的歐拉路叫做歐拉回路。具有歐拉回路的圖叫做歐拉圖。

你的任務是:對于給定的一組無向圖數據,判斷其是否成其為歐拉圖?

Input

連續T組數據輸入,每組數據第一行給出兩個正整數,分別表示結點數目N(1 < N <= 1000)和邊數M;隨后M行對應M條邊,每行給出兩個正整數,分別表示該邊連通的兩個結點的編號,結點從1~N編號。

Output

若為歐拉圖輸出1,否則輸出0。

Sample Input

1
6 10
1 2
2 3
3 1
4 5
5 6
6 4
1 4
1 6
3 4
3 6

Sample Output

1

Hint

如果無向圖連通并且所有結點的度都是偶數,則存在歐拉回路,否則不存在。

題解:已經給了歐拉回路的判定條件,判定一下圖是否連通,然后就可以判斷一下是不是歐拉回路就可以了。

#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>int n;/*n節點數量*/
int f[1050];/*記錄點是否被遍歷過*/
int INF = 1e9+7;/*相當于無窮大*/
int s[1050][1050];
int num[1050];/*記錄節點的度*/void DFS(int x)
{f[x] = 1;int i;for(i=1;i<=n;i++){if(!f[i]&&s[x][i])DFS(i);}
}int main()
{int t;int m,i,j;scanf("%d",&t);while(t--){scanf("%d%d",&n,&m);for(i=1;i<=n;i++)for(j=1;j<=n;j++)s[i][j] = 0;for(i=1;i<=n;i++)num[i] = f[i] = 0;for(i=0;i<m;i++)/*輸入邊的時候順便把端點的度記錄*/{int a,b;scanf("%d%d",&a,&b);s[a][b] = s[b][a] = 1;num[a] ++;num[b] ++;}for(i=1;i<=n;i++)/*判斷度是否都是偶數*/{if(num[i]%2)break;}if(i!=n+1)/*說明有點的度不是偶數,證明不是歐拉回路*/{printf("0\n");continue;}int ff = 0;for(i=1;i<=n;i++)/*判斷圖是否連通*/{if(!f[i])/*未標記說明是一顆新的樹(圖),對他進行DFS*/{ff ++;/*記錄樹(圖)的數量*/DFS(i);}}if(ff>1)/*樹(圖)的數量不唯一,說明圖不連通*/{printf("0\n");continue;}printf("1\n");}return 0;
}

轉載于:https://www.cnblogs.com/luoxiaoyi/p/10067588.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450072.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450072.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450072.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Tcp三次握手和四次揮手狀態圖

三次握手 四次揮手 正常情況下 同時揮手 SYN攻擊&#xff1a; 在三次握手過程中&#xff0c;Server發送SYN-ACK之后&#xff0c;收到Client的ACK之前的TCP連接稱為半連接&#xff08;half-open connect&#xff09;&#xff0c;此時Server處于SYN_RCVD狀態&#xff0c;當…

QEMU 3.0.0 新特性一覽

QEMU 在 2018年8月15發布了版本3.0.0&#xff0c; 正式從 2.12 進入了3.0 時代。 而且到今年位為止&#xff0c;QEMU 已經有15個年頭了&#xff0c;出乎意料的長阿&#xff0c;:) 其主要新特性如下&#xff1a; ARM&#xff1a; 在virt機器中支持SMMUv3 IOMMU 在v8M中支持VLLDM…

OpenCL、OpenGL 同時工作

視頻處理如果能使用OpenCL、OpenGL、omap將大量提高運算速度&#xff0c;簡單介紹OpenCL、OpenGL 同時工作。 OpenCL和OpenGL都能用于操作GPU&#xff0c;但是前者主要用于通用計算&#xff0c;而后者主要用于圖像渲染。在某些情況下&#xff0c;我們希望能用OpenCL計得到算圖像…

財務自由之路——為什么選擇淘寶(下)

接上文~一、淘寶之前的大佬們是怎么試錯的?我們看看在淘寶之前的大佬們是怎么試錯迭代產品的。都知道飛機是萊特兄弟發明的&#xff0c;但很少有人知道為什么是他們。在內燃機發明后的很長一段時間內全球各地發明家都在投入研究飛機&#xff0c;萊特兄弟相對于其他競爭者&…

java參數后面跟三個點是什么意思

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 AVA中類型后面跟三個點是什么來的。 看代碼中那個三點&#xff0c;這樣做起到重載的作用&#xff0c;但這是什么意思&#xff1f; cla…

一只視頻程序猿的移動直播SDK初體驗

本文轉自一只視頻程序猿的移動直播SDK初體驗&#xff0c;此處僅做排版改動。 今早老板召開站會&#xff0c;“移動直播這么火&#xff0c;市面上有一百多個APP&#xff0c;小斌&#xff0c;你下周交個原型APP瞅瞅!” 小弟心中一萬匹草泥馬奔過&#xff0c;這玩意兒哪兒是幾天就…

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程 一&#xff1a;前言 最近手上壓了一塊米聯客的Miz7035&#xff0c;一塊xilinx zynq-7000系列的開發板&#xff0c;想著正好學習一下linux在ARM9上的移植&#xff0c;網上基本都是ZC702、zed的教程&#xff0c;這對于買了非標…

程序員的創業困境 誰來幫助出出主意?

【編者按】有人說&#xff0c;程序員是吃青春飯的&#xff0c;到一定年齡就得考慮轉行&#xff0c;也有人選擇自己創業。而當創業使你偏離了之前持續學習專業知識的軌道時&#xff0c;你會選擇在創業路上繼續堅持還是回歸自己的老本行&#xff1f;編程編了十幾年的Dan McComas半…

節選—Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目

本文轉載自Android 視頻直播 &#xff08; 從快播到直播&#xff0c;從高清到無碼 )十年視頻開發項目&#xff0c;截取其中技術概念比較相關的部分&#xff0c;并做了重新的排版。 視頻和直播的準備&#xff1a; android-java層&#xff1a;camera相關&#xff08;視頻&#x…

getDeclaredMethod和getMethod的區別

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 getDeclaredMethod*()獲取的是類自身聲明的所有方法&#xff0c;包含public、protected和private方法。getMethod*()獲取的是類的所有共有…

12.5PMP試題每日一題

在什么情況下項目正式受控于實施整體變更控制過程&#xff1a;A、從項目啟動到收尾的所有過程B、只有當項目基準建立之后C、在項目基準建立之前D、只要有人提起變更請求的時候 作者&#xff1a;Tracy19890201&#xff08;同微信號&#xff09; 答案將于明天和新題一起揭曉&…

在線預覽word,excel文檔

Google Doc 示例&#xff1a;https://jsfiddle.net/7xr419yb/ Microsoft Office 示例&#xff1a;https://jsfiddle.net/gcuzq343/轉載于:https://www.cnblogs.com/alexguoyihao/p/10314626.html

如何遷移整個git倉庫

轉自準備更換git托管&#xff0c;如何遷移原git倉庫一個回答 如果你想從別的 Git 托管服務那里復制一份源代碼到新的 Git 托管服務器上的話&#xff0c;可以通過以下步驟來操作。 從原地址克隆一份裸版本庫&#xff0c;比如原本托管于 GitHub。 git clone –bare git://githu…

關于創業:希望有人在N年前就告訴我的一些事兒

【編者按】原文作者為前微軟員工、創業家Amir Khella&#xff0c;他離開微軟后開始自主創業&#xff0c;并成功創辦了多家公司。他經常在博客中分享自己的創業故事和經驗。以下是其中一篇博文&#xff0c;他認為創業者想要成功&#xff0c;首先需要找到自己的方向&#xff0c;再…

Rust核心團隊前成員Brian Anderson加入PingCAP

昨天&#xff0c;國內新型分布式數據庫公司PingCAP聯合創始人兼CEO劉奇在朋友圈宣布&#xff0c;Rust核心團隊前成員Brian Anderson將加入公司。PingCAP聯合創始人兼CTO黃東旭進一步向InfoQ記者證實了此消息&#xff0c;并透露Brian將從事TiKV相關的工作&#xff0c;從存儲引擎…

JeeSite 是什么、概述

見JeeSite官網&#xff1a;http://jeesite4.mydoc.io/ 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 總體概述 快速訪問 JeeSite 官網地址&#xff1a;http://jeesite.comJeeSite 在…

單機單網卡最大tcp長連接數真的是65535嗎?

很早微博上一直討論比較多的問題&#xff0c;這里轉載個知乎的答案&#xff1a;單機單網卡最大tcp長連接數真的是65535嗎&#xff1f; 作者&#xff1a;許懷遠 鏈接&#xff1a;https://www.zhihu.com/question/66553828/answer/244313925 來源&#xff1a;知乎 著作權歸作者…

觀察者模式-Observer Pattern

1.主要優點 觀察者模式的主要優點如下&#xff1a; (1) 觀察者模式可以實現表示層和數據邏輯層的分離&#xff0c;定義了穩定的消息更新傳遞機制&#xff0c;并抽象了更新接口&#xff0c;使得可以有各種各樣不同的表示層充當具體觀察者角色。 (2) 觀察者模式在觀察目標和觀察者…

賭還是不賭 你應該辭職去創業嗎?

【編者按】本文的作者是Amir Khella&#xff0c;他是一位著名的用戶體驗設計師&#xff0c;也是創業顧問和企業家。在過去的三年里&#xff0c;他成功的打造了十幾家公司&#xff0c;其中不少還被大企所收購&#xff0c;比如說Google收購了他的DocVerse&#xff0c;LimeLight N…

Python 深淺copy 和文件操作

深淺copy 1&#xff0c;先看賦值運算。 l1 [1,2,3,[barry,alex]] l2 l1l1[0] 111 print(l1) # [111, 2, 3, [barry, alex]] print(l2) # [111, 2, 3, [barry, alex]]l1[3][0] wusir print(l1) # [111, 2, 3, [wusir, alex]] print(l2) # [111, 2, 3, [wusir, alex]] 對…