제한 시간을 초과하더라도 '부분 점수'를 받을 수 있습니다. ※ 언어별 기본 제공 소스코드 내용 참고
만약, 제한 시간을 초과하지 않았는데도 '부분 점수'를 받았다면, 일부 테스트 케이스를 통과하지 못한 경우 입니다.
메모리 사용 제한 : heap, global, static 총계 256MB, stack 100MB
제출 제한 : 최대 10회
입력
입력 파일에는 여러 테스트 케이스가 포함될 수 있다.
파일의 첫째 줄에 테스트 케이스의 개수를 나타내는 자연수 \(T\)가 주어지고,
이후 차례로 \(T\)개의 테스트 케이스가 주어진다. \((1 ≤ T ≤ 70) \)
각 테스트 케이스의 첫 줄에는 정점의 개수 \(N\), 방향성 정해진 간선의 개수 \(M\), 방향성이 정해지지 않은 간선의 개수 \(K\)가 주어진다. \((\ 3≤N≤500,\ 0≤M≤2,000,\ 1≤K≤2,000\ )\)
정점들은 1번부터 \(N\)번까지 번호가 붙어 있다.
둘째 줄부터 \(M\)개의 각 줄에는 두 정점의 번호가 주어진다. 첫 정점에서 두번째 정점으로 방향이 있는 간선이 있다는 의미이다.
그 다음 \(K\)개의 각 줄에는 두 정점의 번호가 주어진다. 두 정점을 연결하는 방향이 정해지지 않은 간선이 있다는 의미이다. 이 간선들은 주어진 순서대로 번호가 붙어 있다.
하나의 정점을 간선이 연결하는 경우는 없으나, 동일한 쌍의 정점들에 대해 여러 개의 간선이 존재할 수 있다.
점수 : 각 제출에서 취득한 점수 중에서 최대 점수 (만점 180 점)
주어지는 테스트 케이스 데이터들의 그룹은 아래와 같으며,
각 그룹의 테스트 케이스를 모두 맞추었을 때 해당되는 부분 점수를 받을 수 있다.
ㆍ 그룹 1 (41 점) : 이 그룹의 테스트 케이스에서는 \(3≤N≤10,\ 0≤M≤20,\ 1≤K≤10\)이다.
ㆍ 그룹 2 (52 점) : 간선들에 방향을 부여할 수 있는 방법이 유일하다.
ㆍ 그룹 3 (87 점) : 이 그룹의 테스트 케이스에서는 원래의 조건 외에는 다른 제약조건이 없다.
모든 테스트 케이스를 풀지 않고 일부분의 그룹에 속하는 테스트 케이스만을 푸는 경우에도 입력 받은 모든 케이스에 대해 (답이 틀릴지라도) 출력 양식에는 맞는 출력을 생성해야 점수가 반영되는 것이 보장된다.
제한 시간을 초과하면 제출한 소스코드의 프로그램이 즉시 종료되며, 그때까지 출력한 내용이 파일에 저장되지 않아 점수가 제대로 반영되지 않을 수 있습니다.
출력
각 테스트 케이스의 답을 순서대로 표준출력으로 출력하여야 하며,
각 테스트 케이스마다 첫 줄에는 “Case #\(C\)”를 출력하여야 한다. 이때 \(C\)는 테스트 케이스의 번호이다.
그 다음 줄에, 0과 1로 이루어진 문자열을 출력한다. 각 문자는 \(K\)개의 방향성이 정해지지 않은 간선들의 번호 순으로 0인 경우 입력에 주어진 순서 대로 방향을 부여했다는 의미이고 1은 그 반대로 방향을 부여했다는 의미이다. 가능한 답이 여러가지인 경우 사전순으로 가장 빠른 것을 출력하라.