프로그래밍/알고리즘
프로그래머스/위클리 챌린지/직업군 추천하기
Doublsb
2021. 8. 24. 16:02
https://programmers.co.kr/learn/courses/30/lessons/84325
풀이
- 사용 언어와 선호도를 입력하면 적절한 직군을 알려 주는 프로그램
- 주어진 table을 잘 split하는 게 핵심인듯
- 총합이 같은 직군이면 알파벳순으로 빠른 것을 출력한다
- 알파벳순은 SortedDictionary로 해결해야겠다
- 또다시 푸는 방법을 알려준 문제라 큰 고민은 없음
C#
using System;
using System.Collections.Generic;
using System.Linq;
public class Solution {
public string solution(string[] table, string[] languages, int[] preference) {
var DB = new DB(table);
string answer = DB.Find(languages, preference);
return answer;
}
}
public class DB {
private Dictionary<string, Tech> data;
public DB(string[] table){
data = new Dictionary<string, Tech>();
int pos = 0;
for(int i=0; i<table.Length; i++) {
pos = table[i].IndexOf(' ');
data.Add(table[i].Substring(0, pos), new Tech(table[i].Substring(pos + 1)));
}
}
public string Find(string[] lang, int[] prefer){
var score = new SortedDictionary<string, int>();
foreach(var key in data.Keys) {
score.Add(key, 0);
for(int i=0; i<lang.Length; i++) {
score[key] += data[key].Find(lang[i]) * prefer[i];
}
}
return score.First(e => e.Value == score.Values.Max()).Key;
}
}
public class Tech {
private Dictionary<string, int> score;
public Tech(string str){
score = new Dictionary<string, int>();
var strs = str.Split(' ');
for(int i=0; i<strs.Length; i++){
score.Add(strs[i], 5-i);
}
}
public int Find(string language) {
if(score.ContainsKey(language)) return score[language];
else return 0;
}
}
결과
100.0 / 100.0
피드백
-
반응형