자료구조 dfs에서 connected 인지 아닌지를 판단하는 프로그램입니다.
싸리
void dfs(int v)
{
node_pointer w;
visited[v] = TRUE;
printf(%5d, v);
for(w = graph[v] ; w ; w = w-link)
{
if(!visited[w-vertex])
dfs(w-vertex);
}
}void dfnlow(int u, int v) {
node_pointer ptr;
int w;
dfn[u] = low[u] = num++;
for(ptr = graph[u]; ptr; ptr = ptr-link) {
w = ptr-vertex;
if(dfn[w] 0) {
dfnlow(w, u);
low[u] = MIN(low[u], low[w]);
} else if( w != v)
low[u] = MIN(low[u], dfn[w]);
}
}void bicon(int u, int v) {
node_pointer ptr;
int w;
edge e;
dfn[u] = low[u] = num++;
for(ptr = graph[u]; ptr; ptr = ptr-link)
{
w = ptr-vertex;
if(v!=w && dfn[w] dfn[u])
{
set[top].v = u;
set[top].w = w;
++top;
if(dfn[w] 0)
{
bicon(w,u);
low[u] = MIN(low[u], low[w]);
if(low[w] = dfn[u])
{
printf(\nNew biconnected component:\n);
do
{
e = set[--top];
printf(%d,%d, e.v, e.w);
}while( !(e.v == u && e.w == w));
count++;
printf(\n);
}
} else if (w!=v)
{
low[u] = MIN(low[u], dfn[w]);
}
}
}
}
void connected()
{
int i;
for(i = 0 ; i n ; i++)
{
if(!visited[i])
dfs(i);
bicon(i,-1);
}
return ;
}
--------------------------------------------------------------------
코드상에서 New bi component를 생성할 때 count 변수를 1씩 증가시켜서
connected인지 아닌지를 판단하려다가 bi component가 생성될 때마다
count 변수를 증가시켜 판단하는 방식이 아니라는 것을 알게 됐습니다.
계속 생각해봐도 어떤 방식으로 connected인지 아닌지를 판단하는지 몰라서
답답한 마음에 이렇게 글을 올려봅니다.고수님들 좀 도와주세요!!!!!
-
화가마
아까 방금 해결했습니다. 답변 감사합니다!
-
다한
모든 점을 방문한 후에 아직 방문하지 않은점이 있는지 검사해보세요
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |
2691450 | [visual c++ 툴]기초 질문 (3) | 해긴 | 2025-04-13 |