aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAbigail <abigail@abigail.be>2021-11-01 19:00:06 +0100
committerAbigail <abigail@abigail.be>2021-11-01 19:00:06 +0100
commit289bed506e57873ce957f89ab7c4093bb032e482 (patch)
tree6b69dfd355e0813aedf8df622411f3fdeeb9f5c5
parentf1ea467485df825b48e023ae7efb9cc031e94e8a (diff)
downloadperlweeklychallenge-club-289bed506e57873ce957f89ab7c4093bb032e482.tar.gz
perlweeklychallenge-club-289bed506e57873ce957f89ab7c4093bb032e482.tar.bz2
perlweeklychallenge-club-289bed506e57873ce957f89ab7c4093bb032e482.zip
AWK solutions for week 137
-rw-r--r--challenge-137/abigail/awk/ch-1.awk38
-rw-r--r--challenge-137/abigail/awk/ch-2.awk23
2 files changed, 61 insertions, 0 deletions
diff --git a/challenge-137/abigail/awk/ch-1.awk b/challenge-137/abigail/awk/ch-1.awk
new file mode 100644
index 0000000000..f0d29a5887
--- /dev/null
+++ b/challenge-137/abigail/awk/ch-1.awk
@@ -0,0 +1,38 @@
+#!/usr/bin/awk
+
+#
+# See ../README.md
+#
+
+#
+# Run as: awk -f ch-1.awk
+#
+
+BEGIN {
+ m = split ("1600 2000", start_years)
+ n = split ("004 009 015 020 026 " \
+ "032 037 043 048 054 " \
+ "060 065 071 076 082 " \
+ "088 093 099 " \
+ " 105 111 116 122 " \
+ "128 133 139 144 150 " \
+ "156 161 167 172 178 " \
+ "184 189 195 " \
+ " 201 207 212 218 " \
+ "224 229 235 240 246 " \
+ "252 257 263 268 274 " \
+ "280 285 291 296 " \
+ " 303 308 314 " \
+ "320 325 331 336 342 " \
+ "348 353 359 364 370 " \
+ "376 381 387 392 398", long_year_offsets)
+
+ for (j = 1; j <= m; j ++) {
+ for (i = 1; i <= n; i ++) {
+ year = start_years [j] + long_year_offsets [i]
+ if (1900 <= year && year <= 2100) {
+ print year
+ }
+ }
+ }
+}
diff --git a/challenge-137/abigail/awk/ch-2.awk b/challenge-137/abigail/awk/ch-2.awk
new file mode 100644
index 0000000000..281b28dc55
--- /dev/null
+++ b/challenge-137/abigail/awk/ch-2.awk
@@ -0,0 +1,23 @@
+#!/usr/bin/awk
+
+#
+# See ../README.md
+#
+
+#
+# Run as: awk -f ch-2.awk < input-file
+#
+
+function reverse (str) {
+ x = ""
+ for (i = length (str); i != 0; i --) {
+ x = x substr (str, i, 1)
+ }
+ return x
+}
+
+function ly (n) {
+ return n >= 10000000 ? 1 : n == reverse(n) ? 0 : ly(n + reverse(n))
+}
+
+{print ly($1)}