[백준 15429] Odd Gnome (Easy) (C#, C++) - soo:bak
작성일 :
문제 링크https://soo-bak.github.io/algorithm/boj/oddGnome-07/#문제-링크
설명https://soo-bak.github.io/algorithm/boj/oddGnome-07/#설명
주어진 여러 그룹의 노움들 중에서, 각 그룹 별로 순서대로 정렬되지 않은 ‘왕’ 노움을 찾아내는 문제입니다.
각 그룹의 노움들은 증가하는 ID
순서대로 배열되어 있으며, 왕 노움만이 이 순서에서 제외됩니다.
또한, 왕 노움은 절대로 그룹의 첫 번째나 마지막에 오지 않습니다.
각 그룹에 대해서, 첫 번째 노움과 마지막 노움을 제외한 모든 노움을 순회하면서, 왕 노움을 찾아냅니다.
이 때, 왕 노움은 그 앞의 노움 ID
에 1
을 더한 값과 자신의 ID
가 다르며,
동시에, 자신의 ID
에 1
을 더한 값과 그 뒤의 노움 ID
가 다르다는 조건을 활용합니다.
즉, (gnomes[j - 1]
+ 1
!= gnomes[j]
) && (gnomes[j] + 1
!= gnomes[j + 1]
) 조건을 만족하는 노움이 왕 노움이 됩니다.
최종적으로, 각 그룹의 왕 노움의 위치를 찾아 출력합니다.
Codehttps://soo-bak.github.io/algorithm/boj/oddGnome-07/#code
[ C# ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
namespace Solution {
class Program {
static void Main(string[] args) {
var n = int.Parse(Console.ReadLine()!);
for (int i = 0; i < n; i++) {
var inputs = Console.ReadLine()!.Split(' ').Select(int.Parse).ToArray();
var g = inputs[0];
var gnomes = inputs.Skip(1).ToArray();
var kingPosition = Enumerable.Range(1, g - 2)
.FirstOrDefault(j =>
gnomes[j - 1] + 1 != gnomes[j] && gnomes[j] + 1 != gnomes[j + 1]) + 1;
Console.WriteLine(kingPosition);
}
}
}
}
[ C++ ]
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
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n; cin >> n;
for (int i = 0; i < n; i++) {
int g; cin >> g;
vector<int> gnomes(g);
for (int j = 0; j < g; j++)
cin >> gnomes[j];
for (int j = 1; j < g - 1; j++) {
if (gnomes[j - 1] + 1 != gnomes[j] && gnomes[j] + 1 != gnomes[j + 1]) {
cout << j + 1 << "\n";
break ;
}
}
}
return 0;
}