algo
SW Expert Academy Magnetic C++
개발하는 장군감
2021. 9. 16. 01:16
개인적인 풀이이니 참고만 하시길 바랍니다.
건설적인 비판과 의견은 대환영입니다 :)
문제
[S/W 문제해결 기본] 5일차 - Magnetic
https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV14hwZqABsCFAYD
위 문제는 특정 조건을 이해한 단순 구현 문제이다. (유식하게 표현하는 방법이 있다면 댓글로 알려주세요 !)
크게 어렵지 않았으며 N극(빨간색)을 먼저 발견한 다음 S극(파란색)을 발견한 경우만 result ++ 해주었다.
(내 알고리즘 실력이 늘어서 빨리 푼게 아니라 문제가 쉬웠던거다.. 착각하고 교만하지말자 ㅜ)
코드
#include<iostream>
using namespace std;
int main(int argc, char** argv)
{
int test_case;
int T = 10;
for (test_case = 1; test_case <= T; ++test_case)
{
int mp[100][100];
int N;
int res = 0;
cin >> N;
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++) {
cin >> mp[i][j];
}
}
for (int i = 0; i < N; i++) {
int j = 0;
int cur = 0;
while (j < N) {
if (mp[j][i] == 1) { //빨강 발견
cur = 1;
}
else if (cur == 1 && mp[j][i] == 2) { // 빨강일때 파랑발견
res++;
cur = 2;
}
j++;
}
}
cout << "#" << test_case << " " << res << endl;
}
return 0;
}
반응형