[JAVA]7. 교육과정 설계 (Queue)

2022. 11. 17. 11:41·코딩 테스트/Java
반응형

설명

현수는 1년 과정의 수업계획을 짜야 합니다.

수업중에는 필수과목이 있습니다. 이 필수과목은 반드시 이수해야 하며, 그 순서도 정해져 있습니다.

만약 총 과목이 A, B, C, D, E, F, G가 있고, 여기서 필수과목이 CBA로 주어지면 필수과목은 C, B, A과목이며 이 순서대로 꼭 수업계획을 짜야 합니다.

여기서 순서란 B과목은 C과목을 이수한 후에 들어야 하고, A과목은 C와 B를 이수한 후에 들어야 한다는 것입니다.

현수가 C, B, D, A, G, E로 수업계획을 짜면 제대로 된 설계이지만

C, G, E, A, D, B 순서로 짰다면 잘 못 설계된 수업계획이 됩니다.

수업계획은 그 순서대로 앞에 수업이 이수되면 다음 수업을 시작하다는 것으로 해석합니다.

수업계획서상의 각 과목은 무조건 이수된다고 가정합니다.

필수과목순서가 주어지면 현수가 짠 N개의 수업설계가 잘된 것이면 “YES", 잘못된 것이면 ”NO“를 출력하는 프로그램을 작성하세요.

 

입력

첫 줄에 한 줄에 필수과목의 순서가 주어집니다. 모든 과목은 영문 대문자입니다.

두 번 째 줄부터 현수가 짠 수업설계가 주어집니다.(수업설계의 길이는 30이하이다)

 

출력

첫 줄에 수업설계가 잘된 것이면 “YES", 잘못된 것이면 ”NO“를 출력합니다.

 

예시 입출력

CBA
CBDAGE
YES

 

설명

queue의 구조(FIFO)만 알면 쉽게 풀 수 있는 문제이다.

필수과목을 queue에 순서대로 넣어준다.
수업계획을 순차적으로 탐색하면서 queue제일 맨 위에 있는 값과 확인하여, 값이 같다면 queue에서 제거
queue에 값이 없으면 조건 성립 return "YES"

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class Main{
    public static String solution(String need, String plan){
        String answer = "NO";
        Queue<Character> q = new LinkedList<>();
        for(char x : need.toCharArray()) q.offer(x);
        for(char x : plan.toCharArray()){
            if(q.peek() == x) q.poll();
            if(q.isEmpty()) return "YES";
        }
        return answer;
    }

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String need = scan.next();
        String plan = scan.next();
        System.out.println(solution(need, plan));
    }
}
/*
다른풀이
public static String solution(String need, String plan){
        String answer = "YES";
        Queue<Character> q = new LinkedList<>();
        for(char x : need.toCharArray()) q.offer(x);
        for(char x : plan.toCharArray()){
            if(q.contains(x)){
                if(x!=q.poll()) return "NO";
            }
        }
        if(!q.isEmpty()) return "NO";
        return answer;
    }
 */
반응형
저작자표시 (새창열림)

'코딩 테스트 > Java' 카테고리의 다른 글

[BOJ]백준 1919번: 애너그램 만들기  (0) 2022.11.16
[JAVA]6. 공주 구하기 (Queue)  (0) 2022.11.16
[프로그래머스]Level2 : 기능개발(JAVA)  (0) 2021.09.29
[프로그래머스]Level 1 : 나누어 떨어지는 숫자 배열(JAVA)  (0) 2021.07.20
[프로그래머스] Level 1 : 시저 암호(JAVA)  (0) 2021.06.06
'코딩 테스트/Java' 카테고리의 다른 글
  • [BOJ]백준 1919번: 애너그램 만들기
  • [JAVA]6. 공주 구하기 (Queue)
  • [프로그래머스]Level2 : 기능개발(JAVA)
  • [프로그래머스]Level 1 : 나누어 떨어지는 숫자 배열(JAVA)
:j
:j
ddongjunn@gmail.com
  • :j
    dev.j
    :j
  • 전체
    오늘
    어제
    • :j
      • 프로그래밍 언어
        • Java
        • html
        • JavaScript
        • XML
        • JSON
        • CSS
        • jQuery
        • Web
        • k8s
        • JPA
      • 프레임워크
        • Spring
      • 코딩 테스트
        • Java
      • 네트워크
        • CCNA
      • 데이터베이스
        • Mssql
        • Oracle
      • 회고
      • :j story
      • CS
  • 블로그 메뉴

    • 홈
    • 태그
    • github
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    MSSQL
    id
    <br>
    Queue
    항해99
    항해플러스백앤드
    class
    멤버변수
    항해솔직후기
    오버로딩
    항해플러스
    다형성
    group by
    지역변수
    HAVING
    오버라이딩
    Name
    항해플러스백엔드
    appendChild
    항해백앤드
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
:j
[JAVA]7. 교육과정 설계 (Queue)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.