정올2006 고등부 지역본선 5번 질문이요..
징징몬
트리의 분할
N개의 정점과 이들 사이에 가중치를 갖는 간선으로 이루어진 트리가 있다. 주어진 자연수 K (K
그림 1
예를 들어 그림 1과 같이 7개의 정점으로 이루어진 트리에서 1번, 2번 정점을 선택하여 그래프를 만들면 그림 2의 (A)와 같이 되고, 나머지 정점들로 그래프를 만들면 그림 2의 (B)와 같이 된다.
그림 2
또한 그림 1의 트리에서 3번, 4번 정점을 선택한 경우 마찬가지로 그림 3의 (A), (B)와 같이 두 그래프가 만들어진다. 그림 3
그림 2의 두 그래프에서 모든 간선의 가중치의 합은 10 + 20 + 10 + 25 = 65가 되고 그림 3의 두 그래프에서 모든 간선의 가중치의 합은 10이 된다.
트리에 대한 정보와 K가 주어질 때, K개의 정점을 선택하여 위와 같은 방법으로 만들어진 두 그래프에 있는 모든 간선의 가중치 합의 최소값을 구하는 프로그램을 작성하시오.
실행 파일의 이름은 TREE.EXE로 하고, 프로그램의 실행시간은 1초를 넘을 수 없다. 부분 점수가 주어질 수 있다.
입력 형식
입력 파일의 이름은 INPUT.TXT로 한다. 첫째 줄에는 N과 K가 빈칸을 사이에 두고 차례로 주어진다. 트리의 정점에는 1번부터 N번까지 번호가 매겨진다. 이어 둘째 줄부터 N-1개의 줄의 각 줄에는 간선 하나의 정보가 주어진다. 간선의 정보는 양 끝 정점 번호와 가중치가 빈 칸을 사이에 두고 차례대로 주어진다. N은 1000이하의 자연수, K는 N보다 작은 자연수이고 간선의 가중치는 1000이하의 자연수이다.
출력 형식
출력 파일의 이름은 OUTPUT.TXT로 한다. 첫째 줄에 K개 정점을 선택하여 만들어진 두 개의 그래프에 있는 모든 간선의 가중치 합의 최소값을 출력하고, 둘째 줄에 그 때 선택한 K개 정점들의 번호를 오름차순으로 빈칸을 사이에 두고 한 줄에 출력한다. K개의 정점을 선택하는 방법이 둘 이상인 경우 그 중 한 경우만 출력한다. 입력과 출력의 예
벡터 컨테이너로 인접 리스트 형식으로 나열하고 가중치 내림순으로 정렬한 다음 하나씩 제거해서 작업하면 되는 줄 알았더니 답과 틀리게 나오네요...ㅡㅡ; 매 번 지우면서 정점에 연결된 간선이 얼마나 남아있는지 일일히 확인하는 과정을 넣을까 생각했지만 너무 계산과정이 많아지는 것 같고.......
이 문제를 어떻게 풀어야 될까요?? ..
-
휑하니
저도 깜짝 놀랬습니다. +_+;;;
저정도 내용은 대학교 2~3학년 수준에서 배우는 내용인데 고등부 내용에 나오다니;;; -
거늘
늦은 나이에 C언어.. 이제 자료구조/알고리즘 배우고 있는데, 너무 부끄럽습니다.. 고등부에서 저런걸 배우다니.. 도대체 난 뭐한건지 -_-;; 쩝;;
-
놀리기
인접 리스트로 구현하라는 말이 기술되지 않았다면 인접 행렬로 구현해서 테스트 해보시는게 어떤가요.
인접 행렬로 구현되있는 그래프는 테스트하기도 쉽고 출력도 쉬우며 한눈에 보기도 편합니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
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 |