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
- implement
- java
- 파이썬
- greedy
- Method
- Class
- string
- two pointers
- database
- Number Theory
- simulation
- 자바
- Binary Tree
- geometry
- array
- Matrix
- Tree
- bit manipulation
- 코딩테스트
- dynamic programming
- hash table
- Data Structure
- Stack
- 코테
- 구현
- Math
- sorting
- Binary Search
- SQL
- Counting
Archives
- Today
- Total
코린이의 소소한 공부노트
[프로그래머스/Lv.1] 기사단원의 무기 본문
숫자나라 기사단의 각 기사에게는 1번부터 number까지 번호가 지정되어 있다. 기사들은 무기점에서 무기를 구매하려고 한다.
각 기사는 자신의 기사 번호의 약수 개수에 해당하는 공격력을 가진 무기를 구매하려 한다. 단, 이웃나라와의 협약에 의해 공격력의 제한수치를 정하고, 제한수치보다 큰 공격력을 가진 무기를 구매해야 하는 기사는 협약기관에서 정한 공격력을 가지는 무기를 구매해야 합니다.
무기를 만들 때 무기의 공격력 1당 1kg의 철이 필요하기 때문에 무기점에서 무기를 모두 만들기 위해 필요한 철의 무게를 미리 계산하려 한다.
1. Input, Output, Example
- 기사단원의 수를 나타내는 정수 number와 이웃나라와 협약으로 정해진 공격력의 제한수치를 나타내는 정수 limit와 제한수치를 초과한 기사가 사용할 무기의 공격력을 나타내는 정수 power가 주어졌을 때, 무기점의 주인이 무기를 모두 만들기 위해 필요한 철의 무게를 반환
2. Constraint
1) 1 ≤ number ≤ 100,000
2) 2 ≤ limit ≤ 100
3) 1 ≤ power ≤ limit
3. Code
import java.util.*;
class Solution {
public int solution(int number, int limit, int power) {
// number 이하의 소수 체크
boolean[] prime = new boolean[number+1];
Arrays.fill(prime, true);
for(int i=2 ; i<=number ; i++)
if(prime[i])
for(int j=2*i ; j<=number ; j+=i)
prime[j] = false;
// 소인수 분해로 약수의 개수 체크
int answer = 0;
for(int i=1 ; i<=number ; i++){
int num = i, index = 2, count = 1;
while(num>1 && index<=i){
int n = 0;
if(prime[index])
while(num%index==0){
n++; num /= index;
}
count *= n+1;
index++;
}
answer += count>limit ? power : count;
}
return answer;
}
}
- +1
'코딩테스트 풀이 > JAVA' 카테고리의 다른 글
[프로그래머스/Lv.1] 완주하지 못한 선수 (0) | 2023.07.04 |
---|---|
[프로그래머스/Lv.1] 숫자 짝꿍 (0) | 2023.07.04 |
[프로그래머스/Lv.1] [1차] 다트 게임 (0) | 2023.07.04 |
[프로그래머스/Lv.1] 실패율 (0) | 2023.07.04 |
[프로그래머스/Lv.1] 소수 찾기 (0) | 2023.07.04 |