Coding Test/Programmers
[프로그래머스] 다단계 칫솔 판매(java)
Heang Lee
2021. 5. 23. 12:19
코딩테스트 연습 - 다단계 칫솔 판매 | 프로그래머스 (programmers.co.kr)
어떻게 생각하고 문제를 풀었는가?
다단계 피라미드 구조를 LinkedList의 구현을 통해 만들고, 부모 노드로 이익의 10%를 전달하는 클래스 함수를 만듦으로서 문제를 해결할 수 있습니다.
주어진 입력은 i번째 판매원의 이름과 부모 판매원의 이름 그리고 i번째 판매 데이터에 저장된 판매원 이름과 판매량입니다.
판매원 이름을 Key 값으로 하는 HashMap을 사용하면 더 빠른 시간내에 판매원 객체를 찾을 수 있습니다.
코드
import java.util.*;
class Solution {
final int PRICE = 100;
public int[] solution(String[] enroll, String[] referral, String[] seller, int[] amount) {
HashMap<String, Salesman> map = new HashMap<>();
Salesman center = new Salesman();
for(int i=0;i<enroll.length;i++){
Salesman salesman = new Salesman();
if(!referral[i].equals("-")){
salesman.parent = map.get(referral[i]);
}else{
salesman.parent = center;
}
map.put(enroll[i],salesman);
}
for(int i=0;i<seller.length;i++){
map.get(seller[i]).addProfit(amount[i]*PRICE);
}
int[] answer = new int[enroll.length];
for(int i=0;i<enroll.length;i++){
answer[i] = map.get(enroll[i]).profit;
}
return answer;
}
class Salesman{
Salesman parent=null;
int profit=0;
public void addProfit(int income){
int tax = (int) (income*0.1f);
if(parent!=null && tax>0){
this.parent.addProfit(tax);
this.profit += income-tax;
}else{
this.profit += income;
}
}
}
}
테스트를 통과하는 코드를 작성하였습니다.
클래스 Salesman을 작성하여 이익을 계산할 때 부모 판매원에게 10%의 이익을 줄 수 있도록 하였으며 반환 값은 enroll의 순서대로 Hashmap에서 Salesman 객체를 꺼내 profit의 값을 원소로 저장함으로서 구할 수 있습니다.
문제를 해결함에 있어 주의해야할 점은 자신의 이익에게 수입의 0.9를 곱해서 더하면 안된다는 점입니다.
예를 들어 12의 income이 주어질 경우 12x0.1 = 1.2, 12x0.9 = 10.8입니다.
int로의 형변환이 이루어질 때 소수점 미만의 값은 버려지기 때문에 1과 10의 결과값이 계산되어집니다.
따라서 자신의 이익은 수입 - (수입 x 0.1)의 값을 더하여 구해야합니다.