개발자 톡
연습문제 톡
[HSAT 6회 정기 코딩 인증평가 기출] 출퇴근길
반례 알려주시면 정말 감사하겠습니다. 소프티어 유튜브 풀이 영상 보고 구현 해봤는데 통과가 안되서요 ㅠㅠ
- 등록일
- 2024-02-15 01:13:47
- 조회수
- 982
- 작성자
- castela0119
import java.io.*; import java.util.*; public class Main { static int N; // 정점의 갯수 static int M; // 간선의 갯수 static ArrayList<Integer>[] graph1; // 정순 static ArrayList<Integer>[] graph2; // 정순 static boolean[] visited1; // 정순 S출발 static boolean[] visited2; // 정순 T출발 static boolean[] visitedR1; // 역순 S출발 static boolean[] visitedR2; // 역순 T출발 public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.readLine()); N = Integer.parseInt(st.nextToken()); M = Integer.parseInt(st.nextToken()); graph1 = new ArrayList[N+1]; graph2 = new ArrayList[N+1]; visited1 = new boolean[N+1]; visited2 = new boolean[N+1]; visitedR1 = new boolean[N+1]; visitedR2 = new boolean[N+1]; for(int i=0; i<N+1; i++) { graph1[i] = new ArrayList<>(); graph2[i] = new ArrayList<>(); } for(int i=0; i<M; i++) { st = new StringTokenizer(br.readLine()); int A = Integer.parseInt(st.nextToken()); int B = Integer.parseInt(st.nextToken()); graph1[A].add(B); // 정순 graph graph2[B].add(A); // 역순 graph } st = new StringTokenizer(br.readLine()); int S = Integer.parseInt(st.nextToken()); int T = Integer.parseInt(st.nextToken()); iterative_BFS(S, T); iterative_BFS2(S, T); iterative_BFS_R1(S, T); iterative_BFS_R2(S, T); int cnt = 0; for(int i=0; i<N+1; i++) { if(visited1[i] == true && visited2[i] == true && visitedR1[i] == true && visitedR2[i] == true && i != S && i != T) { cnt += 1; } } System.out.println(cnt); } public static void iterative_BFS(int start, int end) { Queue<Integer> q = new LinkedList<>(); q.add(start); visited1[start] = true; visited1[end] = true; while(!q.isEmpty()) { int v = q.poll(); for(int w : graph1[v]) { if(visited1[w] == false) { q.add(w); visited1[w] = true; } } } } public static void iterative_BFS2(int start, int end) { Queue<Integer> q = new LinkedList<>(); q.add(end); visited2[end] = true; visited2[start] = true; while(!q.isEmpty()) { int v = q.poll(); for(int w : graph1[v]) { if(visited2[w] == false) { q.add(w); visited2[w] = true; } } } } public static void iterative_BFS_R1(int start, int end) { Queue<Integer> q = new LinkedList<>(); q.add(start); visitedR1[start] = true; visitedR1[end] = true; while(!q.isEmpty()) { int v = q.poll(); for(int w : graph2[v]) { if(visitedR1[w] == false) { q.add(w); visitedR1[w] = true; } } } } public static void iterative_BFS_R2(int start, int end) { Queue<Integer> q = new LinkedList<>(); q.add(end); visitedR2[end] = true; visitedR2[start] = true; while(!q.isEmpty()) { int v = q.poll(); for(int w : graph2[v]) { if(visitedR2[w] == false) { q.add(w); visitedR2[w] = true; } } } } }
#[HSAT_6회_정기_코딩_인증평가_기출]_출퇴근길