aboutsummaryrefslogtreecommitdiff
path: root/challenge-076
diff options
context:
space:
mode:
authorMohammad S Anwar <Mohammad.Anwar@yahoo.com>2020-09-06 23:24:48 +0100
committerGitHub <noreply@github.com>2020-09-06 23:24:48 +0100
commitffe130221044e7732ffa0562d79b4eb1b6e6e0e7 (patch)
tree4e62374390ab93f25991dff13d5f22b79656e5e8 /challenge-076
parent9243d575d94496da3a0f25d0f01d4d5ebaeb5eda (diff)
parente957a97ec56700d3000ff296d7953ec285de96ff (diff)
downloadperlweeklychallenge-club-ffe130221044e7732ffa0562d79b4eb1b6e6e0e7.tar.gz
perlweeklychallenge-club-ffe130221044e7732ffa0562d79b4eb1b6e6e0e7.tar.bz2
perlweeklychallenge-club-ffe130221044e7732ffa0562d79b4eb1b6e6e0e7.zip
Merge pull request #2223 from adamcrussell/challenge-076
initial commit
Diffstat (limited to 'challenge-076')
-rw-r--r--challenge-076/adam-russell/blog.txt1
-rw-r--r--challenge-076/adam-russell/perl/ch-1.pl107
-rw-r--r--challenge-076/adam-russell/perl/ch-2.pl100
-rw-r--r--challenge-076/adam-russell/prolog/ch-1.p96
-rw-r--r--challenge-076/adam-russell/prolog/ch-2.p114
-rw-r--r--challenge-076/adam-russell/prolog/temp.p84
-rw-r--r--challenge-076/adam-russell/words69903
7 files changed, 70405 insertions, 0 deletions
diff --git a/challenge-076/adam-russell/blog.txt b/challenge-076/adam-russell/blog.txt
new file mode 100644
index 0000000000..73d5f1d738
--- /dev/null
+++ b/challenge-076/adam-russell/blog.txt
@@ -0,0 +1 @@
+https://adamcrussell.livejournal.com/17985.html
diff --git a/challenge-076/adam-russell/perl/ch-1.pl b/challenge-076/adam-russell/perl/ch-1.pl
new file mode 100644
index 0000000000..604d015f75
--- /dev/null
+++ b/challenge-076/adam-russell/perl/ch-1.pl
@@ -0,0 +1,107 @@
+use strict;
+use warnings;
+##
+# You are given a number $N.
+# Write a script to find the minimum number
+# of prime numbers required, whose summation gives you $N.
+##
+my @primes = (
+ 2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,
+ 89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,
+ 181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,
+ 281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,
+ 397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,
+ 503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,
+ 619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,
+ 743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,
+ 863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,
+ 997,1009,1013,1019,1021,1031,1033,1039,1049,1051,1061,1063,1069,1087,
+ 1091,1093,1097,1103,1109,1117,1123,1129,1151,1153,1163,1171,1181,1187,
+ 1193,1201,1213,1217,1223,1229,1231,1237,1249,1259,1277,1279,1283,1289,
+ 1291,1297,1301,1303,1307,1319,1321,1327,1361,1367,1373,1381,1399,1409,
+ 1423,1427,1429,1433,1439,1447,1451,1453,1459,1471,1481,1483,1487,1489,
+ 1493,1499,1511,1523,1531,1543,1549,1553,1559,1567,1571,1579,1583,1597,
+ 1601,1607,1609,1613,1619,1621,1627,1637,1657,1663,1667,1669,1693,1697,
+ 1699,1709,1721,1723,1733,1741,1747,1753,1759,1777,1783,1787,1789,1801,
+ 1811,1823,1831,1847,1861,1867,1871,1873,1877,1879,1889,1901,1907,1913,
+ 1931,1933,1949,1951,1973,1979,1987,1993,1997,1999,2003,2011,2017,2027,
+ 2029,2039,2053,2063,2069,2081,2083,2087,2089,2099,2111,2113,2129,2131,
+ 2137,2141,2143,2153,2161,2179,2203,2207,2213,2221,2237,2239,2243,2251,
+ 2267,2269,2273,2281,2287,2293,2297,2309,2311,2333,2339,2341,2347,2351,
+ 2357,2371,2377,2381,2383,2389,2393,2399,2411,2417,2423,2437,2441,2447,
+ 2459,2467,2473,2477,2503,2521,2531,2539,2543,2549,2551,2557,2579,2591,
+ 2593,2609,2617,2621,2633,2647,2657,2659,2663,2671,2677,2683,2687,2689,
+ 2693,2699,2707,2711,2713,2719,2729,2731,2741,2749,2753,2767,2777,2789,
+ 2791,2797,2801,2803,2819,2833,2837,2843,2851,2857,2861,2879,2887,2897,
+ 2903,2909,2917,2927,2939,2953,2957,2963,2969,2971,2999,3001,3011,3019,
+ 3023,3037,3041,3049,3061,3067,3079,3083,3089,3109,3119,3121,3137,3163,
+ 3167,3169,3181,3187,3191,3203,3209,3217,3221,3229,3251,3253,3257,3259,
+ 3271,3299,3301,3307,3313,3319,3323,3329,3331,3343,3347,3359,3361,3371,
+ 3373,3389,3391,3407,3413,3433,3449,3457,3461,3463,3467,3469,3491,3499,
+ 3511,3517,3527,3529,3533,3539,3541,3547,3557,3559,3571,3581,3583,3593,
+ 3607,3613,3617,3623,3631,3637,3643,3659,3671,3673,3677,3691,3697,3701,
+ 3709,3719,3727,3733,3739,3761,3767,3769,3779,3793,3797,3803,3821,3823,
+ 3833,3847,3851,3853,3863,3877,3881,3889,3907,3911,3917,3919,3923,3929,
+ 3931,3943,3947,3967,3989,4001,4003,4007,4013,4019,4021,4027,4049,4051,
+ 4057,4073,4079,4091,4093,4099,4111,4127,4129,4133,4139,4153,4157,4159,
+ 4177,4201,4211,4217,4219,4229,4231,4241,4243,4253,4259,4261,4271,4273,
+ 4283,4289,4297,4327,4337,4339,4349,4357,4363,4373,4391,4397,4409,4421,
+ 4423,4441,4447,4451,4457,4463,4481,4483,4493,4507,4513,4517,4519,4523,
+ 4547,4549,4561,4567,4583,4591,4597,4603,4621,4637,4639,4643,4649,4651,
+ 4657,4663,4673,4679,4691,4703,4721,4723,4729,4733,4751,4759,4783,4787,
+ 4789,4793,4799,4801,4813,4817,4831,4861,4871,4877,4889,4903,4909,4919,
+ 4931,4933,4937,4943,4951,4957,4967,4969,4973,4987,4993,4999,5003,5009,
+ 5011,5021,5023,5039,5051,5059,5077,5081,5087,5099,5101,5107,5113,5119,
+ 5147,5153,5167,5171,5179,5189,5197,5209,5227,5231,5233,5237,5261,5273,
+ 5279,5281,5297,5303,5309,5323,5333,5347,5351,5381,5387,5393,5399,5407,
+ 5413,5417,5419,5431,5437,5441,5443,5449,5471,5477,5479,5483,5501,5503,
+ 5507,5519,5521,5527,5531,5557,5563,5569,5573,5581,5591,5623,5639,5641,
+ 5647,5651,5653,5657,5659,5669,5683,5689,5693,5701,5711,5717,5737,5741,
+ 5743,5749,5779,5783,5791,5801,5807,5813,5821,5827,5839,5843,5849,5851,
+ 5857,5861,5867,5869,5879,5881,5897,5903,5923,5927,5939,5953,5981,5987,
+ 6007,6011,6029,6037,6043,6047,6053,6067,6073,6079,6089,6091,6101,6113,
+ 6121,6131,6133,6143,6151,6163,6173,6197,6199,6203,6211,6217,6221,6229,
+ 6247,6257,6263,6269,6271,6277,6287,6299,6301,6311,6317,6323,6329,6337,
+ 6343,6353,6359,6361,6367,6373,6379,6389,6397,6421,6427,6449,6451,6469,
+ 6473,6481,6491,6521,6529,6547,6551,6553,6563,6569,6571,6577,6581,6599,
+ 6607,6619,6637,6653,6659,6661,6673,6679,6689,6691,6701,6703,6709,6719,
+ 6733,6737,6761,6763,6779,6781,6791,6793,6803,6823,6827,6829,6833,6841,
+ 6857,6863,6869,6871,6883,6899,6907,6911,6917,6947,6949,6959,6961,6967,
+ 6971,6977,6983,6991,6997,7001,7013,7019,7027,7039,7043,7057,7069,7079,
+ 7103,7109,7121,7127,7129,7151,7159,7177,7187,7193,7207,7211,7213,7219,
+ 7229,7237,7243,7247,7253,7283,7297,7307,7309,7321,7331,7333,7349,7351,
+ 7369,7393,7411,7417,7433,7451,7457,7459,7477,7481,7487,7489,7499,7507,
+ 7517,7523,7529,7537,7541,7547,7549,7559,7561,7573,7577,7583,7589,7591,
+ 7603,7607,7621,7639,7643,7649,7669,7673,7681,7687,7691,7699,7703,7717,
+ 7723,7727,7741,7753,7757,7759,7789,7793,7817,7823,7829,7841,7853,7867,
+ 7873,7877,7879,7883,7901,7907,7919
+);
+@primes = reverse(@primes);
+
+sub nearest_prime{
+ my($n) = @_;
+ for my $i (0..@primes){
+ return $primes[$i] if($n == $primes[$i]);
+ if($n > $primes[$i] && ($n - $primes[$i] >=2 || $n - $primes[$i] >=3)){
+ return $primes[$i];
+ }
+ }
+ return undef;
+}
+
+sub prime_sum{
+ my($n) = @_;
+ my @p;
+ while($n > 0){
+ my $p = nearest_prime($n);
+ push @p, $p;
+ $n = $n - $p;
+ }
+ return @p;
+}
+
+MAIN:{
+ my $n = $ARGV[0];
+ my @p = prime_sum($n);
+ print join(" + ",@p) . " = $n\n";
+} \ No newline at end of file
diff --git a/challenge-076/adam-russell/perl/ch-2.pl b/challenge-076/adam-russell/perl/ch-2.pl
new file mode 100644
index 0000000000..c6cb28f289
--- /dev/null
+++ b/challenge-076/adam-russell/perl/ch-2.pl
@@ -0,0 +1,100 @@
+use strict;
+use warnings;
+##
+# Word Search
+##
+my @word_grid = (
+ ["B","I","D","E","M","I","A","T","S","U","C","C","O","R","S","T"],
+ ["L","D","E","G","G","I","W","Q","H","O","D","E","E","H","D","P"],
+ ["U","S","E","I","R","U","B","U","T","E","A","S","L","A","G","U"],
+ ["N","G","N","I","Z","I","L","A","I","C","O","S","C","N","U","D"],
+ ["T","G","M","I","D","S","T","S","A","R","A","R","E","I","F","G"],
+ ["S","R","E","N","M","D","C","H","A","S","I","V","E","E","L","I"],
+ ["S","C","S","H","A","E","U","E","B","R","O","A","D","M","T","E"],
+ ["H","W","O","V","L","P","E","D","D","L","A","I","U","L","S","S"],
+ ["R","Y","O","N","L","A","S","F","C","S","T","A","O","G","O","T"],
+ ["I","G","U","S","S","R","R","U","G","O","V","A","R","Y","O","C"],
+ ["N","R","G","P","A","T","N","A","N","G","I","L","A","M","O","O"],
+ ["E","I","H","A","C","E","I","V","I","R","U","S","E","S","E","D"],
+ ["S","E","T","S","U","D","T","T","G","A","R","L","I","C","N","H"],
+ ["H","V","R","M","X","L","W","I","U","M","S","N","S","O","T","B"],
+ ["A","E","A","O","F","I","L","C","H","T","O","D","C","A","E","U"],
+ ["Z","S","C","D","F","E","C","A","A","I","I","R","L","N","R","F"],
+ ["A","R","I","I","A","N","Y","U","T","O","O","O","U","T","P","F"],
+ ["R","S","E","C","I","S","N","A","B","O","S","C","N","E","R","A"],
+ ["D","R","S","M","P","C","U","U","N","E","L","T","E","S","I","L"]
+);
+
+sub get_diagonals{
+ my @diagonals;
+ for my $i (0..@{$word_grid[0]}){
+ my @d;
+ push @d, $word_grid[0]->[$i];
+ my $j = 1;
+ my $k = $i;
+ while($j < @word_grid && $k < @{$word_grid[$j]}){
+ $k++;
+ push @d, $word_grid[$j]->[$k];
+ $j++;
+ }
+ push @diagonals, \@d;
+ }
+ return @diagonals;
+}
+
+sub get_reverse_diagonals{
+ my @reverse_grid = reverse(@word_grid);
+ my @diagonals;
+ for my $i (0..@{$reverse_grid[0]}){
+ my @d;
+ push @d, $reverse_grid[0]->[$i];
+ my $j = 1;
+ my $k = $i;
+ while($j < @reverse_grid && $k < @{$reverse_grid[$j]}){
+ $k++;
+ push @d, $reverse_grid[$j]->[$k];
+ $j++;
+ }
+ push @diagonals, \@d;
+ }
+ return @diagonals;
+}
+
+sub get_columns{
+ my @columns;
+ for my $i (0..@{$word_grid[0]}){
+ $columns[$i] = [];
+ for my $j (0..@word_grid){
+ push @{$columns[$i]}, $word_grid[$j]->[$i];
+ }
+ }
+ return @columns;
+}
+
+sub word_search{
+ my($words, $search) = @_;
+ my @found;
+ for my $s (@{$search}){
+ my @s = grep defined, @{$s};
+ $s = join("", @s);
+ for my $w (@{$words}){
+ my $u = uc($w);
+ my $r = reverse($u);
+ push @found, lc($w) if(($s =~ m/\Q$u/ || $s =~ m/\Q$r/) && length($w) > 3);
+ }
+ }
+ return @found;
+}
+
+MAIN:{
+ my @search=(get_columns(), get_diagonals(), get_reverse_diagonals(), @word_grid);
+ open(WORDS, "words");
+ my $words = do{
+ local $/;
+ <WORDS>;
+ };
+ close(WORDS);
+ my @words = split(/\n/, $words);
+ my @found_words = sort {$a cmp $b} word_search(\@words, \@search);
+ print "Found the following words: " . join(",", @found_words) . "\n";
+} \ No newline at end of file
diff --git a/challenge-076/adam-russell/prolog/ch-1.p b/challenge-076/adam-russell/prolog/ch-1.p
new file mode 100644
index 0000000000..23e73317d9
--- /dev/null
+++ b/challenge-076/adam-russell/prolog/ch-1.p
@@ -0,0 +1,96 @@
+primes([2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83
+,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,
+181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,
+281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,
+397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,
+503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,
+619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,
+743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,
+863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,
+997,1009,1013,1019,1021,1031,1033,1039,1049,1051,1061,1063,1069,1087,
+1091,1093,1097,1103,1109,1117,1123,1129,1151,1153,1163,1171,1181,1187,
+1193,1201,1213,1217,1223,1229,1231,1237,1249,1259,1277,1279,1283,1289,
+1291,1297,1301,1303,1307,1319,1321,1327,1361,1367,1373,1381,1399,1409,
+1423,1427,1429,1433,1439,1447,1451,1453,1459,1471,1481,1483,1487,1489,
+1493,1499,1511,1523,1531,1543,1549,1553,1559,1567,1571,1579,1583,1597,
+1601,1607,1609,1613,1619,1621,1627,1637,1657,1663,1667,1669,1693,1697,
+1699,1709,1721,1723,1733,1741,1747,1753,1759,1777,1783,1787,1789,1801,
+1811,1823,1831,1847,1861,1867,1871,1873,1877,1879,1889,1901,1907,1913,
+1931,1933,1949,1951,1973,1979,1987,1993,1997,1999,2003,2011,2017,2027,
+2029,2039,2053,2063,2069,2081,2083,2087,2089,2099,2111,2113,2129,2131,
+2137,2141,2143,2153,2161,2179,2203,2207,2213,2221,2237,2239,2243,2251,
+2267,2269,2273,2281,2287,2293,2297,2309,2311,2333,2339,2341,2347,2351,
+2357,2371,2377,2381,2383,2389,2393,2399,2411,2417,2423,2437,2441,2447,
+2459,2467,2473,2477,2503,2521,2531,2539,2543,2549,2551,2557,2579,2591,
+2593,2609,2617,2621,2633,2647,2657,2659,2663,2671,2677,2683,2687,2689,
+2693,2699,2707,2711,2713,2719,2729,2731,2741,2749,2753,2767,2777,2789,
+2791,2797,2801,2803,2819,2833,2837,2843,2851,2857,2861,2879,2887,2897,
+2903,2909,2917,2927,2939,2953,2957,2963,2969,2971,2999,3001,3011,3019,
+3023,3037,3041,3049,3061,3067,3079,3083,3089,3109,3119,3121,3137,3163,
+3167,3169,3181,3187,3191,3203,3209,3217,3221,3229,3251,3253,3257,3259,
+3271,3299,3301,3307,3313,3319,3323,3329,3331,3343,3347,3359,3361,3371,
+3373,3389,3391,3407,3413,3433,3449,3457,3461,3463,3467,3469,3491,3499,
+3511,3517,3527,3529,3533,3539,3541,3547,3557,3559,3571,3581,3583,3593,
+3607,3613,3617,3623,3631,3637,3643,3659,3671,3673,3677,3691,3697,3701,
+3709,3719,3727,3733,3739,3761,3767,3769,3779,3793,3797,3803,3821,3823,
+3833,3847,3851,3853,3863,3877,3881,3889,3907,3911,3917,3919,3923,3929,
+3931,3943,3947,3967,3989,4001,4003,4007,4013,4019,4021,4027,4049,4051,
+4057,4073,4079,4091,4093,4099,4111,4127,4129,4133,4139,4153,4157,4159,
+4177,4201,4211,4217,4219,4229,4231,4241,4243,4253,4259,4261,4271,4273,
+4283,4289,4297,4327,4337,4339,4349,4357,4363,4373,4391,4397,4409,4421,
+4423,4441,4447,4451,4457,4463,4481,4483,4493,4507,4513,4517,4519,4523,
+4547,4549,4561,4567,4583,4591,4597,4603,4621,4637,4639,4643,4649,4651,
+4657,4663,4673,4679,4691,4703,4721,4723,4729,4733,4751,4759,4783,4787,
+4789,4793,4799,4801,4813,4817,4831,4861,4871,4877,4889,4903,4909,4919,
+4931,4933,4937,4943,4951,4957,4967,4969,4973,4987,4993,4999,5003,5009,
+5011,5021,5023,5039,5051,5059,5077,5081,5087,5099,5101,5107,5113,5119,
+5147,5153,5167,5171,5179,5189,5197,5209,5227,5231,5233,5237,5261,5273,
+5279,5281,5297,5303,5309,5323,5333,5347,5351,5381,5387,5393,5399,5407,
+5413,5417,5419,5431,5437,5441,5443,5449,5471,5477,5479,5483,5501,5503,
+5507,5519,5521,5527,5531,5557,5563,5569,5573,5581,5591,5623,5639,5641,
+5647,5651,5653,5657,5659,5669,5683,5689,5693,5701,5711,5717,5737,5741,
+5743,5749,5779,5783,5791,5801,5807,5813,5821,5827,5839,5843,5849,5851,
+5857,5861,5867,5869,5879,5881,5897,5903,5923,5927,5939,5953,5981,5987,
+6007,6011,6029,6037,6043,6047,6053,6067,6073,6079,6089,6091,6101,6113,
+6121,6131,6133,6143,6151,6163,6173,6197,6199,6203,6211,6217,6221,6229,
+6247,6257,6263,6269,6271,6277,6287,6299,6301,6311,6317,6323,6329,6337,
+6343,6353,6359,6361,6367,6373,6379,6389,6397,6421,6427,6449,6451,6469,
+6473,6481,6491,6521,6529,6547,6551,6553,6563,6569,6571,6577,6581,6599,
+6607,6619,6637,6653,6659,6661,6673,6679,6689,6691,6701,6703,6709,6719,
+6733,6737,6761,6763,6779,6781,6791,6793,6803,6823,6827,6829,6833,6841,
+6857,6863,6869,6871,6883,6899,6907,6911,6917,6947,6949,6959,6961,6967,
+6971,6977,6983,6991,6997,7001,7013,7019,7027,7039,7043,7057,7069,7079,
+7103,7109,7121,7127,7129,7151,7159,7177,7187,7193,7207,7211,7213,7219,
+7229,7237,7243,7247,7253,7283,7297,7307,7309,7321,7331,7333,7349,7351,
+7369,7393,7411,7417,7433,7451,7457,7459,7477,7481,7487,7489,7499,7507,
+7517,7523,7529,7537,7541,7547,7549,7559,7561,7573,7577,7583,7589,7591,
+7603,7607,7621,7639,7643,7649,7669,7673,7681,7687,7691,7699,7703,7717,
+7723,7727,7741,7753,7757,7759,7789,7793,7817,7823,7829,7841,7853,7867,
+7873,7877,7879,7883,7901,7907,7919]).
+
+nearest_prime(N, [H|T], Prime):-
+ N >= H,
+ N0 is N - H,
+ (N0 == 0; N0 >= 2; N0 >=3),
+ Prime is H,!;
+ nearest_prime(N, T, Prime).
+
+prime_sum(N, Primes, Sum):-
+ prime_sum(N, Primes, [], Sum).
+prime_sum(0, _, Sum, Sum).
+prime_sum(N, Primes, SumAccum, Sum):-
+ nearest_prime(N, Primes, H),
+ N0 is N - H,
+ N0 >= 0,
+ prime_sum(N0, Primes, [H|SumAccum], Sum).
+
+main:-
+ write("N: "),
+ read(N),
+ primes(Primes),
+ reverse(Primes, PrimesDescending),
+ prime_sum(N, PrimesDescending, Sum),
+ write(Sum),
+ write(" sum to "),
+ writeln(N),
+ halt. \ No newline at end of file
diff --git a/challenge-076/adam-russell/prolog/ch-2.p b/challenge-076/adam-russell/prolog/ch-2.p
new file mode 100644
index 0000000000..b309697d6f
--- /dev/null
+++ b/challenge-076/adam-russell/prolog/ch-2.p
@@ -0,0 +1,114 @@
+word_grid([
+ ["B","I","D","E","M","I","A","T","S","U","C","C","O","R","S","T"],
+ ["L","D","E","G","G","I","W","Q","H","O","D","E","E","H","D","P"],
+ ["U","S","E","I","R","U","B","U","T","E","A","S","L","A","G","U"],
+ ["N","G","N","I","Z","I","L","A","I","C","O","S","C","N","U","D"],
+ ["T","G","M","I","D","S","T","S","A","R","A","R","E","I","F","G"],
+ ["S","R","E","N","M","D","C","H","A","S","I","V","E","E","L","I"],
+ ["S","C","S","H","A","E","U","E","B","R","O","A","D","M","T","E"],
+ ["H","W","O","V","L","P","E","D","D","L","A","I","U","L","S","S"],
+ ["R","Y","O","N","L","A","S","F","C","S","T","A","O","G","O","T"],
+ ["I","G","U","S","S","R","R","U","G","O","V","A","R","Y","O","C"],
+ ["N","R","G","P","A","T","N","A","N","G","I","L","A","M","O","O"],
+ ["E","I","H","A","C","E","I","V","I","R","U","S","E","S","E","D"],
+ ["S","E","T","S","U","D","T","T","G","A","R","L","I","C","N","H"],
+ ["H","V","R","M","X","L","W","I","U","M","S","N","S","O","T","B"],
+ ["A","E","A","O","F","I","L","C","H","T","O","D","C","A","E","U"],
+ ["Z","S","C","D","F","E","C","A","A","I","I","R","L","N","R","F"],
+ ["A","R","I","I","A","N","Y","U","T","O","O","O","U","T","P","F"],
+ ["R","S","E","C","I","S","N","A","B","O","S","C","N","E","R","A"],
+ ["D","R","S","M","P","C","U","U","N","E","L","T","E","S","I","L"]
+]).
+
+grid_strings(Grid, Strings):-
+ grid_strings(Grid, [], Strings).
+grid_strings([], Strings, Strings).
+grid_strings([H|T], StringAccum, Strings):-
+ atomics_to_string(H, S),
+ grid_strings(T, [S|StringAccum], Strings).
+
+read_word(InStream,W):-
+ get_code(InStream,Char),
+ check_char_read(Char,Chars,InStream),
+ atom_codes(W,Chars).
+
+check_char_read(10,[],_):- !.
+
+check_char_read(32,[],_):- !.
+
+check_char_read(-1,[],_):- !.
+
+check_char_read(end_of_file,[],_):- !.
+
+check_char_read(Char,[Char|Chars],InStream):-
+ get_code(InStream,NextChar),
+ check_char_read(NextChar,Chars,InStream).
+
+read_file(S, []):-
+ at_end_of_stream(S).
+read_file(S, end_of_stream):-
+ at_end_of_stream(S).
+read_file(S, [H|T]):-
+ \+ at_end_of_stream(S),
+ read_word(S, H),
+ read_file(S, T).
+
+row_length([H|_], Columns):-
+ length(H, Columns).
+
+column([H|T], Counter, C, Value):-
+ C0 is Counter + 1,
+ C0 == C,
+ Value is H;
+ C0 is Counter + 1,
+ column(T, C0, C, Value).
+
+column_values([], _, _, Values, Values).
+column_values([L|T], C, Columns, ValAccum, Values):-
+ C0 is C + 1,
+ C0 =< Columns,
+ column(L, 0, C0, Value),
+ column_values(T, C0, Columns, [Value | ValAccum], Values);
+ C0 is C + 1, C0 > Columns, column_values([], C0, Columns, ValAccum, Values).
+
+diagonals([H|T], SubDiagonals):-
+ row_length([H|T], Columns),
+ diagonals([H|T], 0, Columns, [], SubDiagonals).
+
+diagonals([], _, _, Diagonals, Diagonals).
+diagonals([H|T], C, Columns, DiagAccum, SubDiagonals):-
+ column_values([H|T], C, Columns, [], D),
+ C0 is C + 1,
+ C0 =< Columns,
+ string_codes(S, D),
+ diagonals([H|T], C0, Columns, [S|DiagAccum], SubDiagonals);
+ diagonals(T, 0, Columns, DiagAccum, SubDiagonals).
+
+word_found(_, []):-
+ fail.
+word_found(Word, [H|T]):-
+ sub_string(H, _, _, _, Word);
+ word_found(Word, T).
+
+word_search(Dictionary, Grid, Words):-
+ word_search(Dictionary, Grid, [], Words).
+word_search([], _, Words, Words).
+word_search([H|T], Grid, WordAccum, Words):-
+ string_upper(H, W),
+ word_found(W, Grid),
+ word_search(T, Grid, [W|WordAccum], Words);
+ word_search(T, Grid, WordAccum, Words).
+
+main:-
+ open("words", read, S), %http://www-personal.umich.edu/~jlawler/wordlist.html
+ read_file(S, Lines),
+ close(S),
+ word_grid(WG),
+ diagonals(WG, Diagonals0),
+ reverse(WG, GW),
+ diagonals(GW, Diagonals1),
+ grid_strings(WG, Strings),
+ flatten([Strings, Diagonals0, Diagonals1], Grid),
+ word_search(Lines, Grid, Words),
+ writeln(Words),
+ halt. \ No newline at end of file
diff --git a/challenge-076/adam-russell/prolog/temp.p b/challenge-076/adam-russell/prolog/temp.p
new file mode 100644
index 0000000000..12e4295d8c
--- /dev/null
+++ b/challenge-076/adam-russell/prolog/temp.p
@@ -0,0 +1,84 @@
+word_grid([
+ ["B","I","D","E","M"],
+ ["L","D","E","G","G"],
+ ["U","S","E","I","R"],
+ ["N","G","N","I","Z"],
+ ["T","G","M","I","D"],
+ ["S","R","E","N","M"],
+ ["S","C","S","H","A"],
+ ["H","W","O","V","L"]
+]).
+
+read_word(InStream,W):-
+ get_code(InStream,Char),
+ check_char_read(Char,Chars,InStream),
+ atom_codes(W,Chars).
+
+check_char_read(10,[],_):- !.
+
+check_char_read(32,[],_):- !.
+
+check_char_read(-1,[],_):- !.
+
+check_char_read(end_of_file,[],_):- !.
+
+check_char_read(Char,[Char|Chars],InStream):-
+ get_code(InStream,NextChar),
+ check_char_read(NextChar,Chars,InStream).
+
+read_file(S, []):-
+ at_end_of_stream(S).
+read_file(S, end_of_stream):-
+ at_end_of_stream(S).
+read_file(S, [H|T]):-
+ \+ at_end_of_stream(S),
+ read_word(S, H),
+ read_file(S, T).
+
+row_length([H|_], Columns):-
+ length(H, Columns).
+ %Columns is 19.
+
+column([H|T], Counter, C, Value):-
+ C0 is Counter + 1,
+ C0 == C,
+ Value is H;
+ C0 is Counter + 1,
+ column(T, C0, C, Value).
+
+column_values([], _, _, Values, Values).
+column_values([L|T], C, Columns, ValAccum, Values):-
+ C0 is C + 1,
+ C0 =< Columns,
+ column(L, 0, C0, Value),
+ column_values(T, C0, Columns, [Value | ValAccum], Values);
+ C0 is C + 1, C0 > Columns, column_values([], C0, Columns, ValAccum, Values).
+
+diagonals([H|T], SubDiagonals):-
+ row_length([H|T], Columns),
+ diagonals([H|T], 0, Columns, [], SubDiagonals).
+
+diagonals([], _, _, Diagonals, Diagonals).
+diagonals([H|T], C, Columns, DiagAccum, SubDiagonals):-
+ column_values([H|T], C, Columns, [], D),
+ C0 is C + 1,
+ C0 =< Columns,
+ diagonals([H|T], C0, Columns, [D|DiagAccum], SubDiagonals);
+ diagonals(T, 0, Columns, DiagAccum, SubDiagonals).
+
+print_diagonals([]).
+print_diagonals([H|T]):-
+ string_codes(S, H),
+ writeln(S),
+ print_diagonals(T).
+
+main:-
+ %word_grid(WG),
+ %writeln(WG),
+ %diagonals(WG, Diagonals),
+ %print_diagonals(Diagonals),
+ open("/usr/share/dict/words", read, S),
+ read_file(S, Lines),
+ close(S),
+ writeln(Lines),
+ halt. \ No newline at end of file
diff --git a/challenge-076/adam-russell/words b/challenge-076/adam-russell/words
new file mode 100644
index 0000000000..055073fe53
--- /dev/null
+++ b/challenge-076/adam-russell/words
@@ -0,0 +1,69903 @@
+a
+a-horizon
+a-ok
+aardvark
+aardwolf
+ab
+aba
+abaca
+abacist
+aback
+abactinal
+abacus
+abaddon
+abaft
+abalienate
+abalienation
+abalone
+abampere
+abandon
+abandoned
+abandonment
+abarticulation
+abase
+abased
+abasement
+abash
+abashed
+abashment
+abasia
+abasic
+abate
+abatement
+abating
+abatis
+abatjour
+abattis
+abattoir
+abaxial
+abba
+abbacy
+abbatial
+abbatical
+abbatis
+abbe
+abbess
+abbey
+abbot
+abbreviate
+abbreviated
+abbreviation
+abbreviature
+abc
+abcoulomb
+abdal
+abderite
+abdicable
+abdicant
+abdicate
+abdication
+abdicator
+abditory
+abditos
+abdomen
+abdominal
+abdominocentesis
+abdominoscope
+abdominoscopy
+abdominous
+abdominousness
+abdominovesical
+abduce
+abducent
+abduct
+abduction
+abductive
+abductor
+abeam
+abecedarian
+abecedarius
+abecedary
+abed
+abel
+abelia
+abelmoschus
+abelmosk
+abends
+aber
+aberdeen
+aberdevine
+aberrance
+aberrant
+aberration
+abest
+abet
+abetalipoproteinemia
+abetment
+abettor
+abeunt
+abeyance
+abeyant
+abfarad
+abhenry
+abhor
+abhorrence
+abhorrent
+abhorrer
+abibis
+abidance
+abide
+abiding
+abidjan
+abience
+abient
+abies
+abigail
+abiit
+abilities
+ability
+abiogenesis
+abiogenetic
+abiogenist
+abiotrophy
+abito
+abject
+abjection
+abjectly
+abjectness
+abjunction
+abjuration
+abjurationabjurement
+abjure
+abkari
+ablactation
+ablated
+ablation
+ablative
+ablaut
+ablaze
+ablaze(p)
+able
+ablebodied
+ablegate
+ableism
+ableness
+ablepharia
+ablepsia
+ablepsy
+abloom
+ablude
+ablution
+ablutionary
+abnaki
+abnegation
+abnegator
+abnormal
+abnormality
+abnormalize
+abnormally
+abnormis
+abnormity
+abnormous
+aboard
+abocclusion
+abode
+abodement
+aboding
+abohm
+aboideau
+abois
+aboiteau
+abolengo
+abolish
+abolishable
+abolishment
+abolition
+abolitionary
+abolitionism
+abolitionist
+abolitionize
+abomasal
+abomasum
+abominable
+abominate
+abomination
+abominator
+aborad
+aboral
+abord
+aboriginal
+aborigine
+aborigines
+aborning
+abort
+aborticide
+abortifacient
+abortion
+abortionist
+abortive
+abortively
+abortus
+abound
+abounding
+about
+about(p)
+about-face
+abouts
+above
+above-mentioned
+aboveboard
+aboveground
+abovementioned
+abovesaid
+abovestairs
+abra
+abracadabra
+abrachia
+abrade
+abraded
+abrader
+abraham
+abramis
+abranchiate
+abrasion
+abrasive
+abreast
+abrege
+abreption
+abridge
+abridged
+abridger
+abridgment
+abroach
+abroad
+abrocoma
+abrocome
+abrogate
+abrogated
+abrogation
+abronia
+abrupt
+abruption
+abruptly
+abruptness
+abruzzi
+abscess
+abscessed
+abscind
+abscision
+abscissa
+abscission
+abscond
+absconder
+abscondment
+absence
+absens
+absent
+absentee
+absenteeism
+absently
+absentminded
+absentmindedness
+absento
+absents
+absinth
+absinthe
+absolute
+absolutely
+absoluteness
+absolution
+absolutism
+absolutist
+absolve
+absolved
+absolver
+absolvitory
+absolvitur
+absonant
+absonous
+absorb
+absorbable
+absorbate
+absorbed
+absorbefacient
+absorbency
+absorbent
+absorber
+absorbing
+absorption
+absorptivity
+absquatulate
+abstain
+abstainer
+abstemious
+abstemiously
+abstemiousness
+abstention
+absterge
+abstergent
+abstersion
+abstersive
+abstinence
+abstinent
+abstract
+abstracted
+abstractedly
+abstractedness
+abstraction
+abstractionism
+abstractionist
+abstractive
+abstractly
+abstractness
+abstractor
+abstruse
+abstrusely
+absurd
+absurdity
+absurdly
+absurdness
+absurdum
+abudefduf
+abulia
+abulic
+abuna
+abundance
+abundant
+abundanti
+abundantly
+abuse
+abused
+abuser
+abusive
+abusively
+abut
+abutilon
+abutment
+abuttal
+abutter
+abutting
+abuzz
+abvolt
+abwatt
+aby
+abysm
+abysmal
+abyss
+abyssal
+abyssinian
+ac
+acacia
+academia
+academic
+academical
+academically
+academician
+academicianship
+academist
+academy
+acadia
+acadian
+acalypha
+acanthaceae
+acanthisitta
+acanthocephala
+acanthocephalan
+acanthocereus
+acanthocybium
+acanthocyte
+acanthocytosis
+acanthoid
+acantholysis
+acanthoma
+acanthophis
+acanthopterygii
+acanthoscelides
+acanthosis
+acanthotic
+acanthuridae
+acanthurus
+acanthus
+acapnic
+acapulco
+acardia
+acariasis
+acariatre
+acaricide
+acarid
+acaridae
+acarina
+acarine
+acaritre
+acarophobia
+acarpelous
+acarpous
+acarus
+acatalectic
+acataphasia
+acathexia
+acathexis
+acaudate
+acaulescent
+accedas
+accede
+accelerando
+accelerate
+accelerated
+accelerating
+acceleration
+accelerative
+accelerator
+accelerometer
+accension
+accent
+accented
+accentor
+accents
+accentual
+accentuate
+accentuation
+accept
+accepta
+acceptability
+acceptable
+acceptably
+acceptance
+acceptation
+accepted
+accepting
+acception
+acceptive
+acceptor
+access
+accessible
+accession
+accessional
+accessorial
+accessory
+acciaccatura
+accidence
+accident
+accident-prone
+accidental
+accidentally
+accidentalness
+accidents
+accipere
+accipient
+accipiter
+accipitres
+accipitridae
+accipitriformes
+accipitrine
+acclaim
+acclamate
+acclamation
+acclimatization
+acclimatize
+acclivitous
+acclivity
+acclivous
+accloy
+accolade
+accommodate
+accommodating
+accommodation
+accommodational
+accommodative
+accomodation
+accompanied
+accompaniment
+accompanist
+accompany
+accompanying
+accompli
+accomplice
+accomplish
+accomplishable
+accomplished
+accomplishment
+accomplishments
+accompts
+accord
+accordance
+accordant
+accordian
+according
+accordingly
+accordion
+accordionist
+accost
+accouchement
+accoucheur
+accoucheuse
+account
+accountability
+accountable
+accountable(p)
+accountableness
+accountancy
+accountant
+accountantship
+accounter
+accounting
+accounts
+accouple
+accouplement
+accousente
+accouter
+accoutered
+accouterment
+accouterments
+accoy
+accra
+accredit
+accreditation
+accredited
+accretion
+accretionary
+accretive
+accrimination
+accroach
+accrue
+accrued
+accrust
+accubation
+accueil
+accultural
+acculturation
+acculturational
+accumbent
+accumulate
+accumulated
+accumulation
+accumulative
+accuracy
+accurate
+accurately
+accurse
+accursed
+accusable
+accusation
+accusative
+accusatorial
+accusatory
+accuse
+accused
+accuser
+accusing
+accusingly
+accustom
+accustomary
+accustomed
+ace
+acebutolol
+aceite
+aceldama
+acentric
+acephalia
+acephalous
+acequia
+acequiador
+acequiamadre
+acer
+aceraceae
+acerate
+aceration
+acerb
+acerbate
+acerbic
+acerbity
+acerola
+acervate
+acervatim
+acervation
+acervulus
+acervus
+acescent
+acetabular
+acetabulum
+acetal
+acetaldehyde
+acetamide
+acetaminophen
+acetanilide
+acetate
+acetic
+acetone
+acetonic
+acetophenetidin
+acetose
+acetous
+acetyl
+acetylcholine
+acetylene
+acetylenic
+acetylic
+achaean
+achar
+acharn
+acharne
+acharnement
+achates
+ache
+achene
+achenial
+acheron