티스토리 뷰
1. 문제
https://programmers.co.kr/learn/courses/30/lessons/12981?language=java
코딩테스트 연습 - 영어 끝말잇기
3 ["tank", "kick", "know", "wheel", "land", "dream", "mother", "robot", "tank"] [3,3] 5 ["hello", "observe", "effect", "take", "either", "recognize", "encourage", "ensure", "establish", "hang", "gather", "refer", "reference", "estimate", "executive"] [0,0]
programmers.co.kr
2. 풀이
- 끝말잇기에 사용된 단어들을 리스트에 저장한다.
- 현재 순서의 단어가 리스트 내에 있지 않으면 끝말잇기 성공, 있으면 단어가 중복된 것이므로 실패한다.
3. 코드
import java.util.*;
class Solution {
public int[] solution(int n, String[] words) {
int[] answer = new int[2];
LinkedList<String> list = new LinkedList<String>();
char beforeEnd = words[0].charAt(words[0].length() - 1); // 이전 단어의 끝말
list.add(words[0]);
int cnt = 1;
boolean isEnded = false;
for(int i = 1; i < words.length; i++){
String word = words[i];
cnt++;
if(beforeEnd == word.charAt(0) && !list.contains(word)){ // 끝말잇기 성공
beforeEnd = word.charAt(word.length() - 1);
list.add(word);
}else{ // 끝말잇기 실패
isEnded = true;
break;
}
}
if(isEnded == false) { // 탈락자가 발생하지 않는 경우
answer[0] = 0;
answer[1] = 0;}
else { // 탈락자가 발생한 경우
answer[0] = cnt % n == 0 ? n : cnt % n;
answer[1] = (int)Math.ceil((float)cnt / n);
}
return answer;
}
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[JAVA/스택] 프로그래머스 짝지어 제거하기 (0) | 2022.08.17 |
---|---|
[JAVA/스택] 프로그래머스 올바른 괄호 (0) | 2022.08.17 |
[JAVA/구현] 프로그래머스 오픈채팅방 (0) | 2021.11.24 |
[JAVA/수학] 프로그래머스 멀쩡한 사각형 (0) | 2021.11.17 |
[JAVA/문자열] 프로그래머스 문자열 압축 (0) | 2021.11.17 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 워드프레스
- 라즈베리파이
- 라즈비안
- dht11
- 메일서버
- c++
- ESP8266
- 집배원 한상덕
- FTP
- mysql
- 자바
- 키 순서
- 스티커모으기2
- 11503
- 합승 택시 요금
- 백준
- 아두이노
- hc-06
- git
- 2981
- dovecot
- 구슬 탈출2
- DP
- 프로그래머스
- 블루투스
- java
- the pads
- hackerrank
- BFS
- 리눅스
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
글 보관함