디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

이거 푸는사람 천재

프갤러(222.111) 2024.05.18 01:41:20
조회 112 추천 0 댓글 1


#include <stdio.h>
#include <stdlib.h>
#define MAX_VERTICES 10

#define SWAP(x, y, t) ((t) = (x), (x) = (y), (y) = (t))

typedef struct GraphNode
{
    int vertex;
    struct GraphNode *link;
} GraphNode;

typedef struct GraphType
{
    int n; // 정점의 개수
    GraphNode *adj_list[MAX_VERTICES];
} GraphType;

// 그래프 초기화
void graph_init(GraphType *g)
{
    int v;
    g->n = 0;
    for (v = 0; v < MAX_VERTICES; v++)
        g->adj_list[v] = NULL;
}
// 정점 삽입 연산
void insert_vertex(GraphType *g, int v)
{
    if (((g->n) + 1) > MAX_VERTICES)
    {
        fprintf(stderr, "그래프: 정점의 개수 초과");
        return;
    }
    g->n++;
}
// 간선 삽입 연산, v를 u의 인접 리스트에 삽입한다.
void insert_edge(GraphType *g, int u, int v)
{
    GraphNode *node;
    if (u >= g->n || v >= g->n)
    {
        fprintf(stderr, "그래프: 정점 번호 오류");
        return;
    }
    node = (GraphNode *)malloc(sizeof(GraphNode));
    node->vertex = v;
    node->link = g->adj_list[u];
    g->adj_list[u] = node;
}

GraphType g;
void print_arr(int arr[], int in[], int s, int i, int size)
{
    for (int j = 0; j < g.n; j++)
        printf("%3d", in[j]);
    printf("\n");
    for (int j = 0; j < g.n; j++)
        printf("%3d", arr[j]);
    printf("  - s:%d, i:%d, size:%d\n", s, i, size);
}
void generate(int arr[], int s, int size, int *in)
{
    int i, tmp;
    int in_degree[MAX_VERTICES] = {0};
    for (i = 0; i < g.n; i++) // copy
        in_degree[i] = in[i];

    GraphNode *node = g.adj_list[arr[s]]; // 각 정점의 진입 차수를 변경
    while (node != NULL)
    {
        in_degree[node->vertex]--;
        node = node->link;
    }

    s++;
    if (s == g.n)
    {
        for (i = 0; i < g.n; i++)
            printf("정점%d->", arr[i]);
        printf("\n");
    }
    else
    {
        for (i = s; i < size; i++)
        {
            if (in_degree[arr[i]] == 0)
            {
                SWAP(arr[s], arr[i], tmp);
                generate(arr, s, size, in_degree);
                SWAP(arr[s], arr[i], tmp);
            }
        }
    }
}
// 위상정렬을 수행한다.
void topo_sort()
{
    int i, tmp;
    int arr[MAX_VERTICES], size;
    int in_degree[MAX_VERTICES];

    // 모든 정점의 진입 차수를 계산
    for (i = 0; i < g.n; i++) // 초기화
        in_degree[i] = 0;
    for (i = 0; i < g.n; i++)
    {
        GraphNode *node = g.adj_list[i]; // 정점 i에서 나오는 간선들
        while (node != NULL)
        {
            in_degree[node->vertex]++;
            node = node->link;
        }
    }
    // 진입 차수가 0인 정점을 배열에 삽입
    size = 0;
    for (i = 0; i < g.n; i++)
    {
        if (in_degree[i] == 0)
            arr[size++] = i;
    }
    // 모든 위상 순서를 생성
    for (i = 0; i < size; i++)
    {
        generate(arr, i, size, in_degree);
    }
}

int main(void)
{
    graph_init(&g);
    // 문제에 주어진 그래프에 대한 인접리스트를 완성하시오.
    insert_vertex(&g, 0);
    insert_vertex(&g, 1);
    insert_vertex(&g, 2);
    insert_vertex(&g, 3);
    insert_vertex(&g, 4);
    insert_vertex(&g, 5);

    // 정점 0의 인접 리스트 생성
    insert_edge(&g, 0, 2);
    insert_edge(&g, 0, 3);

    // 정점 1의 인접 리스트 생성
    insert_edge(&g, 1, 3);
    insert_edge(&g, 1, 4);

    // 정점 2의 인접 리스트 생성
    insert_edge(&g, 2, 3);
    insert_edge(&g, 2, 5);

    // 정점 3의 인접 리스트 생성
    insert_edge(&g, 3, 5);

    // 정점 4의 인접 리스트 생성
    insert_edge(&g, 4, 5);

    // 위상 정렬
    topo_sort();
    // 동적 메모리 반환 코드 생략
    return 0;
}
/*실제출력

*/
/*출력예시
정점0->정점1->정점2->정점4->정점3->정점5->
정점0->정점1->정점2->정점3->정점4->정점5->
정점0->정점1->정점4->정점2->정점3->정점5->
정점0->정점2->정점1->정점4->정점3->정점5->
정점0->정점2->정점1->정점3->정점4->정점5->
정점1->정점0->정점4->정점2->정점3->정점5->
정점1->정점0->정점2->정점4->정점3->정점5->
정점1->정점0->정점2->정점3->정점4->정점5->
정점1->정점4->정점0->정점2->정점3->정점5->
계속하려면 아무 키나 누르십시오 . . .
*/


아무리 생각해도 안됨 

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
등록순정렬 기준선택
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 힘들게 성공한 만큼 절대 논란 안 만들 것 같은 스타는? 운영자 24/06/10 - -
2709740 나이몇살 연봉몇천 ㅍㅌㅊ?! [13] 헬마스터갤로그로 이동합니다. 06.09 118 0
2709739 일본 IT 하청업체 수준에 실망했습니다 [8] 프로외노자갤로그로 이동합니다. 06.09 109 0
2709738 님들 인생 쉽게 가려고 하는순간 망조든다 [1] 프갤러(222.108) 06.09 50 0
2709737 자기객관화가 안돼서 평가 좀요 [5] ㅇㅇ(125.132) 06.09 101 0
2709736 내 프로젝트에 비추 왜 주는거야? [1] 이시꾸갤로그로 이동합니다. 06.09 44 1
2709735 독도 주변 해양조사에…일본 "사전동의 받아라" 또 억지 발명도둑잡기갤로그로 이동합니다. 06.09 19 0
2709734 나다 프리덤 [1] 프리덤건담갤로그로 이동합니다. 06.09 32 1
2709733 월요일날 첫출근인데 너무 떨린다 [6] ㅇㅇ(175.210) 06.09 59 0
2709731 “표현의 자유가 흔들리고 있다”···미국 반전 시위 진압 비판 목소리 발명도둑잡기갤로그로 이동합니다. 06.09 18 0
2709730 파이썬이 느리다는건 소리로만 들었는데 [2] ㅌㅌ갤로그로 이동합니다. 06.09 97 0
2709729 류류자키 [1] 류류(118.235) 06.09 28 1
2709727 다음엔 똥풍선이 아니라 생화학풍선일것 [1] ㅇㅇ(110.70) 06.09 23 0
2709726 "성조기·태극기·욱일기, 함께 나부끼나... 정부 한미일 군사협력 규탄" 발명도둑잡기갤로그로 이동합니다. 06.09 21 0
2709725 류자키 [2] 따당이갤로그로 이동합니다. 06.09 46 0
2709724 이번엔 저도 똥풍선이란것을 볼수있을까요? [2] 헬마스터갤로그로 이동합니다. 06.09 26 0
2709723 이명박 대통령만들기 공작 '콘크리트 어항' 청계천, 생태하천으로 거듭날까 [1] 발명도둑잡기갤로그로 이동합니다. 06.09 32 0
2709722 똥풍선 다시 날라온다고 함 [2] 헬마스터갤로그로 이동합니다. 06.09 31 0
2709721 20대에 사랑을 경험하지 못하고 늙는단건... [5] 프갤러(118.235) 06.09 81 3
2709720 노호무를 따르는 자들이여 모여라!(노호무 사진 첨부) [8] 나트륨찡갤로그로 이동합니다. 06.09 44 0
2709718 "40억 아파트 종부세 0원... 더 감세하겠단 민주당, 말이 되나" [1] 발명도둑잡기갤로그로 이동합니다. 06.09 27 0
2709715 호정13대 집합! [16] 멍청한유라ㅋ갤로그로 이동합니다. 06.09 62 0
2709714 스레드에 똥글이나 중2병 같은 글 쓰는사람 개많네 [2] 프갤러(218.39) 06.09 31 0
2709713 유라씨 여자만나는법좀 [6] linux갤로그로 이동합니다. 06.09 42 0
2709712 살기 힘들다 ㅇㅅㅇ [3] 나트륨찡갤로그로 이동합니다. 06.09 32 0
2709711 북한, '인권동토대' 출판, 우리 정부 '북한인권보고서'에 맞불 발명도둑잡기갤로그로 이동합니다. 06.09 19 0
2709710 여자들이 남자들에게 냉소적으로 변하는 과정 [13] 멍청한유라ㅋ갤로그로 이동합니다. 06.09 123 0
2709709 와 흐린이 금마 장가갔다고? [14] linux갤로그로 이동합니다. 06.09 48 0
2709708 개발자는 어캐 연애함? 조언좀 가능하신분 [7] 딘퐁갤로그로 이동합니다. 06.09 101 0
2709707 여자랑 눈맞으면 순식간이더라 [6] ㅇㅇ(172.226) 06.09 89 0
2709706 나트륨이 친구 없는 이유 [2] 나트륨찡갤로그로 이동합니다. 06.08 39 0
2709704 응 나트륨 친구 없써~~~~~~~~~ [4] 나트륨찡갤로그로 이동합니다. 06.08 39 0
2709703 디자이너랑 어울리지마라 [3] ㅇㅇ(172.226) 06.08 62 0
2709702 멍유 그사람은 서민의 탈을 쓴 기만자입니다 [3] linux갤로그로 이동합니다. 06.08 32 0
2709699 군인이 확성기로 북에 방송을 하면 합법 민간인이 확성기로 북에 방송을? 발명도둑잡기갤로그로 이동합니다. 06.08 21 0
2709697 오늘의교훈 엔진드로낼 필요가 없는데.. 도리스아(119.195) 06.08 17 0
2709695 Complete [1] 도리스아(119.195) 06.08 29 0
2709694 과나-벌레들이 사는 세상 발명도둑잡기갤로그로 이동합니다. 06.08 13 0
2709692 슬슬 잠 온당.. [1] ♥냥덩수면과학연구소♥갤로그로 이동합니다. 06.08 25 0
2709689 나님 음악천재✨ [1] ♥냥덩수면과학연구소♥갤로그로 이동합니다. 06.08 19 0
2709688 뺐으 보국전자직원이 전화로 청소하려면 다 분해야 한다고 도리스아(119.195) 06.08 21 0
2709687 그래도 똘이장군보다는 도리스아가 백 배는 착하다 발명도둑잡기갤로그로 이동합니다. 06.08 16 0
2709686 오늘의 발명 실마리: 디씨인싸이드 보이스 녹음 기능 다운로더 발명도둑잡기갤로그로 이동합니다. 06.08 21 0
2709685 이거 도리랑 비슷하지? [3] 멍청한유라ㅋ갤로그로 이동합니다. 06.08 33 0
2709682 도리스아 너무 안타까운 게 [3] 발명도둑잡기갤로그로 이동합니다. 06.08 38 0
2709681 어플설치 완료 [6] 멍청한유라ㅋ갤로그로 이동합니다. 06.08 40 1
2709680 . [1/1] ♥냥덩수면과학연구소♥갤로그로 이동합니다. 06.08 28 0
2709679 프붕이 선풍기 모터분해중 [2] 도리스아(119.195) 06.08 29 0
2709677 고민)머리가 특출난거도아니고 adhd있어서 집중력 약한데.. [2] 프갤러(125.141) 06.08 38 0
2709674 나님이 만든 알고리즘으로 프갤 사용자들 이미지를 단어로 요약해냄 ♥냥덩수면과학연구소♥갤로그로 이동합니다. 06.08 22 0
2709673 미니멀리스트의 캘린더 [4] 이시꾸갤로그로 이동합니다. 06.08 45 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2