Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Algorithm, kakao2018 셔틀버스(17678)

어려웠던점

  • 예제 2번을 이해하는데 어려웠다
  • simpledateformat, calender 클래스를 처음 써봐서 헷갈렸다

풀이

  • 셔틀이 오는 시간에 탑승 가능한 최대 탑승객을 태운다
  • 마지막 탑승객을 태우고 빈자리가 있다면 해당시간에 콘은 탑승하면 된다
  • 마지막 탑승객을 태우고 빈자리가 없다면 마지막 탑승객 보다 1분 이전에 탑승하면 된다

전체코드

package org.programmers;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
public class kakao_2018_shuttle_17678 {
	 public String solution(int n, int t, int m, String[] timetable) {
	 String answer = "";
	 // 크루들이 온 시간순으로 정리
	 Arrays.sort(timetable);
	 int nowHour = 9, nowMin = 0;
	 int lastIn = 0, idx = 0;
	 String stringH="09" ,stringM="00" ;
	 while (n > 0) {
	 	 stringH = nowHour<10 ? "0"+nowHour : ""+nowHour;
	 	 stringM= nowMin < 10 ? "0"+nowMin : ""+nowMin; 
	 	 // 셔틀버스의 최대 탑승객수까지만 태운다
	 	 for (int i=0; i<m; i++) {
	 		 // 당일 탑승할 모든 크루가 탑승했으면 끝난다
	 		 if(idx >= timetable.length)
	 			 break;
	 		 // 현재 시각 셔틀버스 이전에 온 크루인지 검사
	 		 if( (stringH+":"+stringM).compareTo(timetable[idx]) >= 0) {
	 			 idx++;
	 			 // 마지막에 탄 크루 수를 계산한다
	 			 if(n==1) lastIn++;
	 		 }
	 	 }
	 	 // 다음 셔틀버스 오는 시간
	 	 --n;
	 	 nowMin += t;
	 	 if (nowMin >= 60) {
	 		 nowHour += 1;
	 		 nowMin -= 60;
	 	 }
	 }
	 // 마지막 셔틀에 탑승한 크루 수가 최대보다 작으면 빈자리가 있으므로 마지막에 온다
	 if (lastIn < m)
	 	 answer = stringH+":"+stringM;
	 // 마지막 셔틀에 빈자리가 없으면 마지막 크루보다 1분 일찍온다
	 else {
	 	 SimpleDateFormat dateformat = new SimpleDateFormat("HH:mm");
	 	 Calendar cal = Calendar.getInstance();
	 	 try {
				cal.setTime(dateformat.parse(timetable[idx-1]));
				cal.add(Calendar.MINUTE, -1);
				answer = dateformat.format(cal.getTime());
	 	 } catch (ParseException e) {
				e.printStackTrace();
	 	 }
	 }
	 return answer;
	 }
}

Reference


Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...