반응형
프로그래머스
2019 카카오 개발자 겨울 인턴십
programmers.co.kr/learn/courses/30/lessons/64061
JAVA
import java.util.ArrayList;
class Solution {
public int solution(int[][] board, int[] moves) {
int answer = 0;
int flag = 0;
int n = board[0].length;
ArrayList temp = new ArrayList();
for(int m=0; m<moves.length; m++) {
int dool = 0;
int mval = moves[m]-1;
for(int i=0; i<n; i++) {
if(board[i][mval] != 0) {
dool = board[i][mval];
board[i][mval] = 0;
break;
}
}
if(dool != 0) {
temp.add(dool);
}
}
while(flag == 0) {
flag = 1;
if(temp.size() > 1) {
for(int i=1; i<temp.size(); i++) {
if(temp.get(i-1) == temp.get(i)) {
temp.remove(i);
temp.remove(i-1);
answer += 2;
flag = 0;
break;
}
}
}
}
for(int i=0; i<temp.size(); i++) {
System.out.println(temp.get(i));
}
return answer;
}
}
JavaScript
function solution(board, moves) {
var answer = 0;
var len = board.length;
var temp = [];
for(var move in moves) {
var m = moves[move] - 1;
for(var i=0; i<len; i++) {
if(board[i][m] != 0) {
if(temp.length != 0 && board[i][m] == temp[temp.length-1]) {
temp.pop();
answer += 2;
} else {
temp.push(board[i][m]);
}
board[i][m] = 0;
break;
}
}
}
return answer;
}
반응형
'코딩테스트 문제풀이 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 로또의 최고 순위와 최저 순위 (0) | 2021.09.28 |
---|---|
[프로그래머스] 짝지어 제거하기 (0) | 2021.09.03 |
[프로그래머스][DFS] 네트워크 (0) | 2020.03.01 |
[프로그래머스] 멀쩡한 사각형 (0) | 2020.03.01 |
[프로그래머스] 괄호 변환 (0) | 2020.02.27 |