aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-03-06 16:56:43 +0800
committercrupest <crupest@outlook.com>2021-03-06 16:56:43 +0800
commit5242b780d8c6aee430bc4a655679ddd5814016b9 (patch)
tree324372327e81fa65cb5b2e794b695cc9e8fb4036
parent7414489d9a211088d5853257baade3986b2b2749 (diff)
downloadcrupest-5242b780d8c6aee430bc4a655679ddd5814016b9.tar.gz
crupest-5242b780d8c6aee430bc4a655679ddd5814016b9.tar.bz2
crupest-5242b780d8c6aee430bc4a655679ddd5814016b9.zip
import(solutions): Add acwing 1219.
-rw-r--r--works/solutions/.gitignore1
-rw-r--r--works/solutions/acwing/1219.cpp26
2 files changed, 27 insertions, 0 deletions
diff --git a/works/solutions/.gitignore b/works/solutions/.gitignore
index f676862..fd9075a 100644
--- a/works/solutions/.gitignore
+++ b/works/solutions/.gitignore
@@ -1,3 +1,4 @@
.vscode
*.exe
*.pdb
+*.ilk
diff --git a/works/solutions/acwing/1219.cpp b/works/solutions/acwing/1219.cpp
new file mode 100644
index 0000000..9538e94
--- /dev/null
+++ b/works/solutions/acwing/1219.cpp
@@ -0,0 +1,26 @@
+#include <cmath>
+#include <iostream>
+
+int w, m, n;
+
+int row(int x) { return (x - 1) / w; }
+
+int col(int x, int r) {
+ int result = (x - 1) % w;
+ if (r % 2) {
+ result = w - 1 - result;
+ }
+ return result;
+}
+
+int main() {
+ std::cin >> w >> m >> n;
+ int m_r = row(m);
+ int m_c = col(m, m_r);
+ int n_r = row(n);
+ int n_c = col(n, n_r);
+
+ std::cout << std::abs(m_r - n_r) + std::abs(m_c - n_c);
+
+ return 0;
+}