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
- Animation State Machine
- ASTAR
- 유니티
- CSharp #자료구조
- raycasting
- 충돌위험 찾기
- heap tree
- 프로그래머스
- 2D슈팅게임
- Algorithm
- Unity
- Blend Type
- pccp 기출문제 3번
- 오브젝트 풀링
- C#
- Back Tracking
- pccp 기출문제 1번
- 플레이어 이동
- 너비 우선 탐색
- 깊이 우선 탐색
- Ainimation Blending
- Lv2
- LayerMark
- pccp 기출문제 2번
- Hpbar
- 플레이어 방향전환
- Scrooling
- Hp바
- Object Poling
- Object Pooling
Archives
- Today
- Total
주녘공부일지
[프로그래머스 C#] Lv.2 혼자 놀기의 달인 본문
https://school.programmers.co.kr/learn/courses/30/lessons/131130/questions
1. 정답코드 및 핵심 아이디어, 유의사항
주어진 조건에 따라 놀이를 진행했을 때, 얻을 수 있는 최고 점수를 구하는 문제
- 1번 상자 x 2번 상자의 값이 최대가 되는 경우를 구해야 함
풀이 순서
1. 임의 선택 - 모든 상자 순회
2. 1번 상자 그룹 개수 찾기
3. 임의 선택 - 열리지 않은 모든 상자 순회
4. 2번 상자 그룹 개수 찾기
5. 1번 상자 x 2번 상자 값이 최고 점수라면 갱신
상자 그룹 개수 찾기
- 열어야 하는 상자가 이미 열려있을 때까지 상자를 열어야 함
- 이 때, 열게 된 상자의 개수가 상자 그룹의 개수가 됨
+ 2번 상자 그룹 개수를 탐색할 때, 1번 상자에서 이미 연 상자도 열려있는 상자
주석 참조
using System;
public class Solution
{
public int solution(int[] cards)
{
int answer = 0;
// 1. 임의 선택 - 모든 상자 순회
for (int i = 0; i < cards.Length; i++)
{
var boolArray1 = new bool[cards.Length]; // 1번 상자 그룹 방문배열
// 2. 1번 상자 그룹 개수 찾기
int count1 = Function(cards, boolArray1, i);
// 3. 임의 선택 - 열리지 않은 모든 상자 순회
for (int j = 0; j < cards.Length; j++)
{
// 열려있는 상자는 탐색하지 않음
if (boolArray1[j])
continue;
var boolArray2 = boolArray1; // 2번 상자 그룹 방문배열
// 4. 2번 상자 그룹 개수 찾기
int count2 = Function(cards, boolArray2, j);
// 5. 최고 점수일 경우 갱신
int score = count1 * count2;
answer = Math.Max(answer, score);
}
}
return answer;
}
// 상자 그룹의 개수를 구하는 메서드
public int Function(int[] cards, bool[] boolArray, int currIndex)
{
int count = 0;
while (boolArray[currIndex] == false)
{
boolArray[currIndex] = true;
currIndex = cards[currIndex] - 1;
count++;
}
return count;
}
}
'CodingTest > Programmers Lv.2' 카테고리의 다른 글
[프로그래머스 C#] Lv.2 과제 진행하기 (0) | 2024.05.22 |
---|---|
[프로그래머스 C#] Lv.2 유사 칸토어 비트열 (0) | 2024.04.01 |
[프로그래머스 C#] Lv.2 교점에 별 만들기 (1) | 2024.03.18 |
[프로그래머스 C#] Lv.2 조이스틱 (2) | 2024.03.16 |
[프로그래머스 C#] Lv.2 당구 연습 (0) | 2024.02.26 |