Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- Hibernate
- SSL
- spring boot
- TLS
- 책 정리
- DISTINCT
- vagrant
- centos7
- db
- EC2
- 프로그래머스
- spring
- 토비의스프링
- WebHook
- sample
- Java
- Linux
- docker
- ssh
- github
- Jenkins
- 코딩테스트
- AWS
- TypeScript
- mariadb
- Git
- Client
- Spring Legacy Project
- window
- jdbc
Archives
- Today
- Total
Woopii Vyeolog
[프로그래머스 코딩테스트 연습] 해시 3 본문
문제 링크 : https://programmers.co.kr/learn/courses/30/parts/12077
3번 문제 : 위장
문제 설명
내가 푼 답(자세한 설명은 주석으로 달아 놓았음)
import java.util.*;
class Solution {
public int solution(String[][] clothes) {
//경우의 수 개념을 활용
//해당 문제에서의 식은 --> (의상종류1 + 1) * (의상 종류2 + 1) - 1 이다
//즉, headgear가 2개고, eyegear가 1이면, (2+1) * (1+1) -1 이 된다.
//그리고, -1 하는 이유는, 아얘 안입는 경우를 제외했기 때문이다.
//answer의 값이 1인 이유는 여기에 경우의 수 곱셈을 해주기 위함이다.
int answer = 1;
HashMap<String, Integer> hm = new HashMap<String, Integer>();
//key값으로 각각의 의상 종류를, value값으로 계산에 필요한 가짓수를 정한다.
for(int i = 0;i < clothes.length;i++){
hm.put(clothes[i][1],hm.getOrDefault(clothes[i][1],1)+1);
}
//answer에 각 의상종류의 value값을 곱함으로서 경우의 수 계산을 한다.
for(HashMap.Entry<String,Integer> aa: hm.entrySet()){
answer *= aa.getValue();
}
//리턴 시 -1 해서 안입는 경우를 제외한다.
return answer-1;
}
}
'코딩테스트 연습' 카테고리의 다른 글
[프로그래머스] 수박수박수박수박수박수? (0) | 2022.04.11 |
---|---|
[프로그래머스] 폰켓몬 (0) | 2022.04.11 |
[프로그래머스 코딩테스트 연습] 해시 2 (0) | 2020.04.22 |
[프로그래머스 코딩테스트 연습] 해시 1 (0) | 2020.04.20 |
코딩테스트 시작하기 (0) | 2020.04.20 |
Comments