기본 콘텐츠로 건너뛰기

오일러 경로와 회로

정점들과 각각의 정점들을 잇는 간선들이 존재한다고 하자.(간선이 연결되지 않은 정점은 고려하지 않는다, 모든 정점에는 적어도 하나 이상의 간선이 연결되어있어야 한다.)

경로는 한 정점에서 출발해 다른 정점에 도달하거나 다시 출발 정점으로 돌아오는 방법이다.

회로는 한 정점에서 출발해 다시 그 정점으로 돌아오는 방법이다.

오일러 경로와 회로는 모든 간선을 한번씩 방문하면서 원하는 정점까지 이동할 수 있는지에 관한 문제이다.

차수는 한 정점에서 다른 정점으로 연결된 간선의 갯수 이다.






그렇다면, 오일러 회로를 존재하게 하는 필요충분 조건은 무엇있까? 

모든 정점의 차수가 짝수 <->오일러 회로가 존재.

모든 정점의 차수가 짝수인 상황을 가정해보자.

시작점이 아닌 차수가 짝수인 정점은 그 정점과 연결된 간선을 모두 한번씩 지나가면 필연적으로 그 정점에서 끝을 맺을 수가 없다. 들어온 숫자 만큼 나가기 때문이다. 따라서 이용할수 있는 마지막 간선을 타고 또다른 정점에 도달하고. 또다른 정점도 아무리 많은 간선을 소모했다 하더라도 마지막 하나는 다른 정점으로 이어주게 된다.

따라서 어떤 간선을 먼저 이용하던간에 궁극적으로 다시 시작 정점에 돌아올 수 밖에 없다. 시작정점도 간선을 통해 나간 수만큼 들어와야 하기 때문이다.

따라서 모든 정점의 차수가 짝수일때는 오일러 회로가 존재하며, 그 어떤 정점도 회로의 시작점이 될 수 있다.

반대로 차수가 홀수인 정점이 존재한다고 해보자.

그렇다면, 모든 간선을 다 한번씩 이용 못하는 경우도 생길 수 있겠다. 또한 모든 간선을 반드시 한번씩 이용하는 경우를 가정했을때도 결국 중간에 껴있는 차수가 홀수인 정점에서 더이상 나아갈 간선이 없이 막혀버린다.

따라서 차수가 홀수인 정점이 존재할때는 반드시 오일러 회로는 존재하지 않는다.





그렇다면, 오일러 경로가 가능해지는 필요충분조건은 무엇일까?

출발정점과 도착정점의 차수가 홀수이며 나머지 정점의 차수가 짝수 or 모든 차수가 짝수 <->오일러 경로가 존재.

위의 증명과 같은 논리로 증명하는데

출발 정점과 도착 정점의 차수만 홀수인 경우를 가정하자.

모든 간선을 한번씩 소모해가면서 앞으로 진행해갈때 출발 정점은 필연적으로 마지막으로 사용한 간선은 다른 정점으로 이동하는데 사용하게되며 다시 출발 정점으로 돌아올 간선은 남지 않게 된다.

도착정점은 연결된 마지막 간선을 반드시 도착정점에 도달하는데 사용하게 된다.

나머지 정점들은 모두 차수가 짝수이므로 반드시 연결된 마지막 간선이 다른 정점으로 나아갈 수 있게 해준다.

만약 두 정점 이외에 차수가 홀수인 점이 존재한다면 반드시 그 정점에서 진행이 불가하다.

또한 한 정점만 홀수라면 모든 간선을 사용하는게 불가하다. 사실 에초에 한 정점만 홀수개의 간선을 가지는 것은 불가능 하다. 간선이 하나 추가될때마다 두개의 정점의 차수가 하나씩 높아지기 때문이다.

모든 정점의 차수가 짝수라면 위에서 말한대로 오일러 회로가 존재하는 필요충분 조건이기 때문에 오일러 경로 또한 반드시 존재한다.

댓글

댓글 쓰기

이 블로그의 인기 게시물

윈도우 10 마우스(커서) 옆에 자꾸 Progress bar(진행중 아이콘)가 나타난다면

이 글은 윈도우10 사용자 중 자꾸만 마우스 커서 옆에 뭔가가 실행중이라고 진행 아이콘이 뜨는 사람에게 조그마한 희망을 주는 글 입니다. 또한 백그라운드에서 프로그램이 실행되는 경우는 아주 다양하니 이 글에서 제시하는 방법은 수많은 문제 중 한가지 문제의 해결책일 뿐임을 미리 알려드립니다. 본인은 원래 해당컴퓨터에서 바이러스에 걸릴만한 행위를 일체 하지않았다. 토렌트나 웹하드는 전혀 사용하지 않고 인터넷에서 파일도 대기업의 공인된 파일만 다운받아서 썼었다. 그러나 어느 날 부턴가 다음과 같은 현상이 발생하였다. 아무런 프로그램도 실행중이지 않지만 자꾸 마우스 아이콘에 실행중이라고 뜨는 문제였다. 이해를 돕기위한 삽화 나는 실행한 프로그램이 없지만 뭔가가 실행중이라는 것은 백그라운드 서비스가 원인이라는 것이다. 그렇다면 어떤 서비스가 다음과같은 현상을 야기했을까? 나는 작업관리자에서 의심가는 백그라운드 프로세스를 종료해보았다. 바로 vpwalletservice VP.Inc에서 배포한 프로그램이었다. 아니나 다를까 해당 프로세스를 삭제하자마자 현상은 사라졌다. 백그라운드 서비스인만큼 msconfig의 서비스 목록에서도 제거하였고 이제 확실히 이런 현상은 발생하지 않을 것이다. 해당 프로그램은 현재 여러 문제를 야기시키는 것으로 인터넷에서 유명하다. 얼마전에는 해당프로그램이 윈도우 부팅시에 start process as current user get session user token failed 메시지를 띄우게 만들어 부팅을 방해했던 문제도 직접 경험해 본적이있다. 이 경우에도 해결방법은 같다.

Cubase : Serum 사용법(1) : 소개와 오실레이터, 필터, 모듈레이터의 사용법

큐베이스 가상악기 Serum 사용법(1) Serum 소개와 오실레이터, 필터, 모듈레이터의 사용법 1. Serum 이란? 큐베이스에서 사용가능한 가상악기 VST 플러그인 형태로 나온 Software Synthesizer 이다. 사운드의 시각화가 잘 되어있는게 특징이며, 웨이브테이블을 통해 다체로운 사운드를 만들 수 있는게 특징이다. Serum 사용 화면. 2. Serum 의 구조 소프트웨어 신디사이저는 구조는 다음과 같고 Serum도 이러한 구조로 이루어져있다. 신디사이저의 구조 여기에서 각 모듈들이 하는 역활은 다음과 같다. 오실레이터 (Oscillator) : 소리를 발진 시킨다. 필터 (Filter) : 오실레이터로부터 받은 소리를 필터링 한다. 엠프 (Amp) : 필터를 거쳐온 소리를 증폭시켜서 최종적으로 출력한다. 모듈레이터 (Modulator) : 각 모듈(오실레이터, 필터, 엠프)에 ENV, LFO 신호를 줘서 변형을 준다. ENV (Envelope Generator) : ADSR의 패턴을 가지고 신디사이저의 모듈들을 컨트롤 할 수 있는 Envelope를 생성한다. 보통 키보드 게이트의 신호를 통해 작동되어 시간에 따라 변하는 전압(Envelope)을 생성한다. LFO (Low Frequency Oscillator) : 저주파 발진기로. 저주파 패턴을 만들어서 음성을 변조하는대 사용한다. 그리고 Serum에서 각 모듈의 위치는 다음과 같다. Serum의 모듈 위치 3. Serum 각 모듈별 사용법 - 오실레이터(Oscillator) 오실레이터에서 Osc A, B가 활성화 되어있다 오실레이터는 크게 Sub와 Noise, Osc A, Osc B로 이루어져 있다. Sub는 기본파형을 발생시킬수 있으며 Noise는 치지직거리는 배경 잡음을 발생시키고, Osc A와 B는 각각 웨이브테이블을 이용해 다양한 파형의 소리를 발진시킨다. 각 요소...

C++ 프로그래밍에서의 메모리 제한(C++)

Visual C++에서는 배열을 선언할때 매모리 제한으로 258257까지만 할당할 수 있다고 한다. 따라서, 1차원 배열은 [258257]이 최대이고 이차원 대략 [508][508] 삼차원은 대략 [63][63][63]까지 할당할 수 있다고한다. 그래서 직접해봤다. 다음 코드를 작성하면 이런 결과를 볼 수 있다. #include <iostream> using namespace std; int main() {  int a[258258];  cin >> a[0]; return 0; } Unhandled exception at 0x0F3B9B32 (ucrtbased.dll) in example1.exe: 0xC00000FD: Stack overflow (parameters: 0x00000001, 0x01042FF4). 오 정말로 스텍오버플로우가 발생한다!!! 이번엔, 배열을 258257까지 선언해보았다. #include <iostream> using namespace std; int main() {  int a[258257];  cin >> a[0];  return 0; } Unhandled exception at 0x770AFA6E (ntdll.dll) in example1.exe: 0xC00000FD: Stack overflow (parameters: 0x00000001, 0x00602F74). 어라????!! 대체 어디까지 줄여야 스택오버플로우가 안뜨나 해봤다. 그 크기는 항상 달랐다. 대략 250000이하부터 안전해 지는 거 같다. 왠만하면 배열을 100000이상으로 안쓰는게 좋겠다. 게다가 변수를 하나만 선언해 놓고 쓰는것도 아니니까 실질적으로 선언할 수 있는 많이 줄어들 것이다. Dev C++에선 그 크기가 약간 다른거 같다. Dev C++을 이용해본 결과 배열을 [519828]...