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 |
Tags
- 2870번 c++
- 유니티
- 백준 2870번
- 백준 1103번
- 플레이어 이동
- Beakjoon
- 백준 1103번 c++
- 백준 1103번 게임
- c++
- 백준 17070번 c++
- 17070번
- 수학숙제
- 백준 c++ 2468번
- Lv2
- Lv.3
- C#
- 2870번 수학숙제 c++
- 2870번
- Unity
- 코테
- 코딩테스트
- 2870번 수학숙제
- Algorithm
- dfs
- 백준
- 2468 c++
- 백준 17070번
- 백준 c++ 2870번
- 오브젝트 풀링
- 프로그래머스
Archives
- Today
- Total
주녘공부일지
[프로그래머스 C#] Lv.2 의상 본문
https://school.programmers.co.kr/learn/courses/30/lessons/42578
1. 정답코드 및 핵심 아이디어, 유의사항
주어진 의상의 종류별 개수를 구하여 이를 이용해 의상 종류별 개수에 따른 수식을 적용하면 되는 문제
1) 의상 종류별 개수 구하기
- 의상의 종류를 키 값으로 Dctionary에 담아서 개수를 카운트
2) 수식
ex. 의상 종류 1가지 = a
ex. 의상 종류 2가지 = a + b + ab
ex. 의상 종류 3가지 = a + b + c + ab + bc + ac + abc
... 이런식으로 진행되는데, 이는 이런 방식으로 변경할 수 있음
-> (a + 1)(b + 1) = a + b + ab + 1
( 각 수식 뒤에 +1 -1을 붙여 곱셈식으로 변환 )
의상 종류 1가지 = (a + 1) - 1
의상 종류 2가지 = (a + 1)(b + 1) - 1
의상 종류 3가지 = (a + 1)(b + 1)(c + 1) - 1
즉, (1번째 의상의 개수 + 1) ... (n번째 의상의 개수 + 1) - 1
주석 참조
using System;
using System.Collections.Generic;
public class Solution
{
public int solution(string[,] clothes)
{
int answer = 1;
var dict = new Dictionary<string, int>();
// 같은 의상종류의 개수를 딕셔너리에 담음
for (int i = 0; i < clothes.GetLength(0); i++)
{
if (dict.ContainsKey(clothes[i, 1]))
dict[clothes[i, 1]]++;
else
dict.Add(clothes[i, 1], 1);
}
// 딕셔너리에 담긴 값 + 1을 다 곱함
foreach (int num in dict.Values)
answer *= num + 1;
return answer - 1;
}
}
'CodingTest > Programmers Lv.2' 카테고리의 다른 글
[프로그래머스 C#] Lv.2 멀리 뛰기 (0) | 2023.12.12 |
---|---|
[프로그래머스 C#] Lv.2 프로세스 (0) | 2023.12.11 |
[프로그래머스 C#] Lv.2 이진 변환 반복하기 (0) | 2023.12.10 |
[프로그래머스 C#] Lv.2 예상 대진표 (0) | 2023.12.10 |
[프로그래머스 C#] Lv.2 삼각 달팽이 (1) | 2023.12.08 |