일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- StringBuilder
- StringTokenizer
- 백준 11725번 트리의 부모 찾기
- kotlin
- Java
- 백준 2206번 벽 부수고 이동하기 G3
- 백준 1240번 노드사이의 거리
- dp
- map
- 프로그래머스 java
- HashSet
- 전위 중위 후위
- 스프링 다중프로필
- HashMap
- 백준 1600번 말이 되고픈 원숭이
- hash
- Stack
- 프로그래머스 자바
- 프로그래머스
- replace()
- 스프링 on-profile
- 서브모듈 yml
- append
- 백준 1967번 트리의 지름 G4 자바
- 포인트 컷
- 코틀린기초
- toUpperCase
- 백준 8979번 올림픽 S5 자바
- 백준 2660번 회장뽑기 G5
- 백준 2589번 보물섬 G5
- Today
- Total
말하는 컴공감자의 텃밭
프로그래머스 - 폰켓몬 자바(java) Hash 본문
200개의 폰켓몬이 있으면 200/2 = > 100마리를 데려갈 수 있고,
여러 종류가 있는데 가장 많은 종류를 데려가고 싶은 욕심쟁이 문제이다.
N마리의 포켓몬의 중복이 없이 담아서 종류 수를 안다면 편하겠쥬~? -> Hash Set
이후 종류수가 많은지 가져갈 수 있는애가 많은지 비교해서 결과값 출력하면 되겠네요
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | import java.util.*; class Solution { public int solution(int[] nums) { int answer = 0; Set<Integer> set = new HashSet<>(); for(int i = 0; i < nums.length; i++){ set.add(nums[i]); } if(set.size() > nums.length/2){ answer = nums.length/2; }else answer = set.size(); return answer; } } | cs |
후후후 쉽죠
import java.util.*; // set 인터페이스 쓸거니까 유틸 임포트~
class Solution {
public int solution(int[] nums) {
int answer = 0;
Set<Integer> set = new HashSet<>(); // 정수형으로 HashSet 선언~!
for(int i = 0; i < nums.length; i++){ // 반복을 통해서 폰켓몬의 중복없이 종류를 파악합니다. .add로 set에 추가
set.add(nums[i]);
}
if(set.size() > nums.length/2){ // 종류가 데려갈 수 있는 수보다 많다면.
answer = nums.length/2; // 데려갈 수 있는 수가 답.
}else answer = set.size(); // 종류수보다 데려갈 수 있는 수가 크다면, 모든 종류를 데려가면 되겠죠
return answer;
}
}
'알고리즘 > Programmers - Java' 카테고리의 다른 글
프로그래머스 가장 가까운 글자 - 자바 (java) HashMap (0) | 2023.04.29 |
---|---|
프로그래머스 마지막 두 원소 - 자바 (java) Arrays.copyOf (0) | 2023.04.29 |
프로그래머스 - 두 개 뽑아서 더하기 (자바) java Hashset (0) | 2023.04.24 |
프로그래머스 문자열 겹치기 - 자바(java) replace, StringBulider (0) | 2023.04.21 |
프로그래머스 외계어 사전 - 자바(java), HashSet (1) | 2023.04.21 |