https://www.acmicpc.net/problem/1913
이 문제는 사실 N이 크지 않아서
숫자 1이 있는 곳 부터 차례대로 배열에 숫자를 채워나가도 됩니다.
하지만 저는 y=x와 y=-x의 직선으로 4칸으로 나눠서 문제를 해결했습니다.
toNum()함수를 사용하면 1의 시간으로 해당 위치의 숫자를 찾아낼 수 있습니다.
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | #include <iostream> #include <vector> #include <algorithm> #include <queue> #include <string.h> using namespace std; #define ll long long #define MOD (ll)1e15 #define MAX_SIZE (int)1e5 #define mp make_pair #define INF 987654321 #define pii pair<int, int> //ios::sync_with_stdio(false); cin.tie(0); int abs(int n) { return n >= 0 ? n : -n; } int toNum(int i, int j) { if (abs(i) <= j) return 4 * j * j - j + i + 1; else if (abs(i) <= -j) return 4 * j * j - 3 * j - i + 1; else if (abs(j) <= -i) return 4 * i * i + 3 * i + j + 1; else return 4 * i * i + i - j + 1; } int main() { ios::sync_with_stdio(false); cin.tie(0); int n; cin >> n; n /= 2; int k; cin >> k; pii pos; for (int i = -n; i <= n; i++) { for (int j = -n; j <= n; j++) { //toNum함수를 이용하여 1의 시간으로 해당 좌표의 숫자를 알아낼 수 있음. int ret = toNum(i, j); cout << ret << ' '; //입력받은 k와 같으면 pos변수에 저장 if (ret == k) { pos.first = i, pos.second = j; } } cout << '\n'; } cout << pos.first + n + 1 << ' ' << pos.second + n + 1; return 0; } | cs |
'알고리즘 > 구현' 카테고리의 다른 글
[1992] 쿼드 트리 (0) | 2017.07.30 |
---|---|
[14488] 준오는 급식충이야! (0) | 2017.07.29 |
[14649] 문홍안 (0) | 2017.07.27 |
[10986] 나머지 합 (0) | 2017.07.24 |
[3474] 교수가 된 현우 (0) | 2017.07.13 |