250x250
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 | 31 |
Tags
- Hp바
- apk
- Vector3
- Scrooling
- joystick
- 플레이어 이동
- Object Poling
- Prefabs
- 패럴렉스
- Transform
- rotation
- raycasting
- 유니티
- 프리팹
- raycast
- Object Pooling
- Blend Type
- 플레이어 방향전환
- 2D슈팅게임
- rigidbody
- 오브젝트 풀링
- 스크롤링
- Ainimation Blending
- Hpbar
- Parallax
- Unity
- 일시정지
- CSharp #자료구조
- LayerMark
- Animation State Machine
Archives
- Today
- Total
주녘공부일지
[프로그래머스 C#] Lv.2 의상 본문
728x90
https://school.programmers.co.kr/learn/courses/30/lessons/42578
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
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;
}
}
728x90
'Programmers - C# > CodingTest 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 |