aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJared Martin <jaredor+github@gmail.com>2020-05-01 01:35:40 -0500
committerJared Martin <jaredor+github@gmail.com>2020-05-01 01:35:40 -0500
commit504fe4e14f846d19626032f57e0fc0ca78dc400c (patch)
tree924584a870418b36b4f3582f664ef64960c22a83
parent044eac044c4cca71a2c2c5eed863df7ed7df7836 (diff)
downloadperlweeklychallenge-club-504fe4e14f846d19626032f57e0fc0ca78dc400c.tar.gz
perlweeklychallenge-club-504fe4e14f846d19626032f57e0fc0ca78dc400c.tar.bz2
perlweeklychallenge-club-504fe4e14f846d19626032f57e0fc0ca78dc400c.zip
This works for both procedural and recursive. Need to add command line options.
-rwxr-xr-xchallenge-058/jaredor/perl/ch-2.pl244
1 files changed, 244 insertions, 0 deletions
diff --git a/challenge-058/jaredor/perl/ch-2.pl b/challenge-058/jaredor/perl/ch-2.pl
new file mode 100755
index 0000000000..a64964c328
--- /dev/null
+++ b/challenge-058/jaredor/perl/ch-2.pl
@@ -0,0 +1,244 @@
+#!/usr/bin/env perl
+
+use strict;
+use warnings;
+use Data::Dump qw(pp);
+use Getopt::Long;
+use List::Util qw(any);
+
+# TASK #2 › Ordered Lineup
+#
+# Write a script to arrange people in a lineup according to how many taller
+# people are in front of each person in line. You are given two arrays. @H is a
+# list of unique heights, in any order. @T is a list of how many taller people
+# are to be put in front of the corresponding person in @H. The output is the
+# final ordering of people’s heights, or an error if there is no solution.
+
+my (@H, @T, @A);
+
+# @H = qw(2 6 4 5 1 3);
+# @T = qw(1 0 2 0 1 2);
+# @A = qw(5 1 2 6 3 4);
+
+# @H = (27, 21, 37, 4, 19, 52, 23, 64, 1, 7, 51, 17, 24, 50, 3, 2,
+# 34, 40, 47, 20, 8, 56, 14, 16, 42, 38, 62, 53, 31, 41, 55, 59,
+# 48, 12, 32, 61, 9, 60, 46, 26, 58, 25, 15, 36, 11, 44, 63, 28,
+# 5, 54, 10, 49, 57, 30, 29, 22, 35, 39, 45, 43, 18, 6, 13, 33);
+#
+# @T = ( 6, 41, 1, 49, 38, 12, 1, 0, 58, 47, 4, 17, 26, 1, 61, 12,
+# 29, 3, 4, 11, 45, 1, 32, 5, 9, 19, 1, 4, 28, 12, 2, 2,
+# 13, 18, 19, 3, 4, 1, 10, 16, 4, 3, 29, 5, 49, 1, 1, 24,
+# 2, 1, 38, 7, 7, 14, 35, 25, 0, 5, 4, 19, 10, 13, 4, 12);
+#
+# @A = (35, 23, 5, 64, 37, 9, 13, 25, 16, 44, 50, 40, 2, 27, 36, 6,
+# 18, 54, 20, 39, 56, 45, 12, 47, 17, 33, 55, 30, 26, 51, 42, 53,
+# 49, 41, 32, 15, 22, 60, 14, 46, 24, 59, 10, 28, 62, 38, 58, 63,
+# 8, 48, 4, 7, 31, 19, 61, 43, 57, 11, 1, 34, 21, 52, 29, 3);
+
+# @H = ( 555, 532, 757, 939, 541, 573, 947, 503, 308, 148, 61, 820,
+# 973, 865, 270, 230, 399, 643, 82, 642, 171, 591, 850, 494,
+# 338, 699, 164, 431, 155, 922, 792, 772, 517, 909, 770, 564,
+# 143, 997, 498, 354, 19, 127, 797, 120, 401, 375, 688, 890,
+# 982, 137, 810, 467, 407, 20, 83, 182, 420, 466, 760, 429,
+# 81, 808, 689, 42, 433, 830, 544, 194, 745, 550, 937, 297,
+# 129, 56, 196, 525, 172, 956, 121, 640, 226, 553, 151, 803,
+# 274, 551, 885, 254, 351, 437, 684, 685, 798, 664, 738, 842,
+# 486, 211, 310, 981, 37, 295, 301, 208, 243, 6, 657, 410,
+# 700, 915, 65, 539, 13, 479, 938, 753, 916, 413, 652, 662,
+# 506, 419, 625, 25, 435, 53, 312, 397, 469, 998, 668, 649,
+# 212, 40, 287, 966, 343, 581, 500, 69, 111, 321, 158, 387,
+# 988, 119, 718, 166, 427, 826, 109, 679, 736, 331, 439, 326,
+# 769, 139, 141, 450, 883, 839, 585, 597, 242, 395, 173, 41,
+# 711, 162, 54, 595, 10, 14, 742, 9, 306, 715, 146, 576,
+# 547, 655, 548, 362, 477, 669, 752, 960, 244, 732, 279, 667,
+# 628, 72, 722, 822, 955, 520, 832, 703, 43, 949, 903, 762,
+# 204, 841, 350, 693, 140, 386, 529, 381, 329, 400, 255, 912,
+# 80, 924, 272, 763, 754, 150, 203, 462, 26, 835, 299, 497,
+# 571, 170, 89, 377, 492, 623, 276, 38, 552, 666, 460, 156,
+# 74, 900, 969, 369, 577, 382, 425, 964, 359, 482, 488, 302,
+# 827, 507, 328, 771, 959, 690, 292, 963, 765, 409, 615, 927,
+# 965, 142, 18, 490, 115, 463, 501, 639, 895, 675, 365, 929,
+# 508, 946, 889, 360, 453, 414, 714, 665, 118, 73, 801, 240,
+# 241, 15, 728, 380, 780, 756, 931, 557, 950, 543, 412, 612,
+# 877, 246, 812, 944, 976, 791, 316, 654, 263, 526, 122, 993,
+# 103, 269, 768, 673, 926, 530, 786, 98, 739, 875, 723, 123,
+# 852, 473, 787, 794, 580, 962, 408, 618, 441, 867, 130, 106,
+# 892, 776, 213, 48, 880, 838, 214, 281, 646, 656, 341, 720,
+# 510, 8, 193, 471, 607, 385, 899, 906, 980, 853, 104, 896,
+# 908, 854, 989, 283, 987, 729, 227, 904, 458, 727, 277, 509,
+# 721, 88, 531, 147, 534, 228, 347, 602, 819, 327, 36, 825,
+# 371, 309, 451, 27, 575, 376, 286, 743, 670, 778, 5, 370,
+# 610, 24, 21, 34, 528, 476, 799, 184, 201, 538, 587, 157,
+# 7, 342, 70, 325, 790, 210, 32, 674, 802, 691, 953, 750,
+# 317, 659, 505, 481, 545, 3, 229, 417, 716, 710, 268, 383,
+# 876, 30, 76, 621, 712, 499, 455, 285, 603, 275, 96, 215,
+# 837, 781, 177, 746, 683, 570, 600, 483, 828, 972, 961, 416,
+# 174, 446, 470, 461, 999, 542, 836, 535, 353, 958, 319, 549,
+# 57, 238, 132, 823, 789, 99, 1, 632, 356, 163, 484, 967,
+# 218, 361, 901, 637, 647, 706, 582, 884, 282, 428, 379, 943,
+# 237, 751, 396, 300, 735, 940, 614, 117, 102, 145, 697, 487,
+# 933, 178, 424, 834, 296, 304, 58, 247, 116, 731, 923, 849,
+# 176, 563, 225, 454, 779, 217, 774, 793, 472, 948, 90, 415,
+# 905, 990, 323, 183, 519, 749, 910, 928, 169, 613, 565, 598,
+# 627, 975, 334, 265, 298, 422, 346, 358, 457, 249, 17, 389,
+# 782, 159, 305, 220, 391, 881, 452, 250, 634, 680, 280, 405,
+# 63, 694, 660, 189, 260, 29, 878, 567, 855, 695, 868, 882,
+# 168, 540, 345, 974, 862, 805, 257, 807, 324, 755, 348, 859,
+# 708, 942, 599, 340, 443, 617, 601, 663, 831, 303, 986, 977,
+# 682, 337, 108, 635, 97, 594, 588, 107, 11, 45, 64, 339,
+# 569, 806, 200, 811, 388, 372, 52, 970, 144, 432, 864, 562,
+# 844, 724, 681, 609, 886, 861, 860, 638, 644, 504, 917, 51,
+# 394, 702, 209, 851, 4, 512, 995, 866, 726, 94, 165, 951,
+# 128, 192, 800, 430, 696, 631, 167, 804, 474, 518, 373, 925,
+# 869, 873, 653, 863, 902, 698, 572, 846, 707, 135, 747, 112,
+# 12, 153, 725, 493, 579, 79, 16, 421, 992, 893, 809, 546,
+# 185, 945, 126, 671, 630, 219, 320, 764, 687, 589, 766, 514,
+# 584, 495, 398, 149, 741, 932, 71, 60, 221, 318, 611, 511,
+# 994, 705, 744, 480, 478, 709, 796, 256, 795, 984, 67, 378,
+# 278, 311, 658, 775, 777, 289, 719, 459, 253, 78, 55, 692,
+# 231, 833, 971, 533, 872, 404, 75, 100, 887, 191, 363, 251,
+# 35, 393, 870, 179, 233, 561, 843, 748, 252, 307, 235, 368,
+# 134, 449, 578, 44, 468, 355, 330, 314, 264, 258, 560, 261,
+# 759, 522, 605, 626, 921, 266, 152, 205, 436, 367, 911, 262,
+# 447, 568, 222, 661, 186, 114, 678, 920, 489, 898, 93, 288,
+# 783, 86, 392, 199, 332, 442, 131, 101, 616, 590, 978, 583,
+# 918, 245, 521, 66, 110, 438, 829, 979, 366, 954, 593, 1000,
+# 406, 335, 991, 919, 62, 402, 734, 322, 491, 22, 516, 411,
+# 445, 28, 236, 879, 271, 59, 608, 574, 650, 858, 894, 930,
+# 284, 502, 267, 448, 648, 556, 374, 784, 84, 874, 47, 821,
+# 85, 180, 313, 364, 897, 390, 206, 651, 845, 202, 125, 344,
+# 740, 952, 788, 913, 475, 524, 68, 291, 761, 767, 464, 133,
+# 824, 888, 629, 223, 907, 566, 423, 704, 418, 730, 847, 216,
+# 294, 558, 606, 818, 357, 586, 426, 636, 91, 39, 46, 161,
+# 941, 92, 857, 440, 624, 914, 641, 293, 619, 485, 713, 983,
+# 816, 154, 336, 813, 197, 676, 31, 686, 188, 207, 840, 815,
+# 444, 49, 496, 273, 33, 77, 957, 434, 871, 604, 349, 113,
+# 195, 384, 701, 515, 935, 190, 465, 352, 513, 50, 537, 456,
+# 248, 848, 403, 672, 592, 23, 536, 817, 620, 758, 936, 136,
+# 733, 105, 160, 554, 290, 856, 175, 773, 138, 232, 198, 187,
+# 934, 596, 737, 124, 985, 234, 968, 559, 315, 259, 2, 95,
+# 633, 996, 785, 645, 333, 814, 239, 527, 181, 891, 677, 224,
+# 87, 622, 717, 523);
+#
+# @T = ( 286, 253, 160, 50, 295, 291, 10, 243, 607, 356, 578, 135,
+# 20, 33, 617, 426, 463, 149, 610, 301, 419, 333, 130, 34,
+# 516, 151, 331, 437, 354, 70, 205, 35, 376, 38, 104, 435,
+# 713, 1, 48, 192, 179, 344, 8, 63, 447, 546, 162, 12,
+# 1, 241, 56, 37, 402, 460, 857, 207, 470, 156, 1, 10,
+# 411, 108, 87, 958, 130, 155, 384, 179, 253, 306, 20, 591,
+# 650, 198, 543, 437, 141, 17, 256, 31, 154, 269, 84, 141,
+# 116, 251, 110, 258, 586, 177, 32, 220, 101, 25, 178, 2,
+# 116, 724, 633, 11, 310, 120, 59, 679, 640, 721, 215, 570,
+# 36, 79, 580, 51, 395, 417, 61, 88, 23, 504, 267, 182,
+# 412, 560, 352, 458, 147, 53, 490, 441, 367, 0, 122, 89,
+# 511, 23, 465, 19, 294, 219, 253, 666, 640, 444, 72, 296,
+# 10, 599, 160, 361, 492, 19, 172, 160, 246, 95, 438, 280,
+# 161, 635, 431, 421, 42, 87, 8, 343, 628, 269, 136, 703,
+# 26, 143, 34, 43, 645, 746, 224, 246, 280, 116, 572, 420,
+# 121, 264, 417, 557, 96, 42, 173, 5, 712, 62, 553, 188,
+# 197, 191, 44, 35, 3, 170, 77, 140, 193, 11, 26, 118,
+# 0, 37, 430, 121, 107, 362, 21, 429, 545, 255, 654, 48,
+# 217, 67, 262, 169, 98, 162, 127, 364, 460, 117, 634, 85,
+# 68, 224, 265, 171, 346, 303, 14, 602, 77, 289, 53, 124,
+# 707, 28, 28, 75, 65, 604, 172, 5, 425, 250, 98, 671,
+# 33, 384, 338, 46, 23, 48, 586, 18, 185, 404, 327, 58,
+# 32, 33, 414, 458, 698, 173, 216, 102, 13, 317, 241, 16,
+# 463, 27, 75, 226, 442, 423, 44, 69, 435, 346, 40, 37,
+# 98, 233, 209, 97, 80, 177, 60, 389, 6, 2, 65, 302,
+# 37, 96, 139, 20, 11, 180, 293, 175, 690, 343, 191, 5,
+# 254, 97, 83, 147, 0, 229, 32, 205, 175, 76, 45, 34,
+# 19, 344, 127, 118, 377, 32, 140, 77, 440, 65, 61, 375,
+# 99, 215, 776, 61, 83, 82, 586, 248, 338, 274, 77, 29,
+# 305, 752, 289, 138, 342, 156, 23, 74, 19, 120, 240, 40,
+# 20, 140, 0, 26, 10, 167, 342, 78, 162, 244, 145, 438,
+# 4, 605, 240, 88, 439, 389, 449, 165, 1, 196, 378, 111,
+# 223, 302, 278, 771, 248, 171, 690, 131, 266, 153, 686, 420,
+# 385, 528, 248, 586, 208, 486, 67, 285, 559, 78, 255, 295,
+# 972, 27, 13, 562, 41, 180, 320, 212, 60, 3, 3, 231,
+# 219, 299, 244, 500, 129, 377, 405, 362, 174, 112, 95, 463,
+# 116, 346, 851, 261, 33, 296, 545, 197, 80, 385, 560, 372,
+# 56, 129, 736, 83, 249, 68, 302, 297, 136, 6, 12, 44,
+# 464, 70, 405, 9, 0, 156, 73, 436, 350, 36, 197, 263,
+# 370, 470, 257, 121, 132, 379, 434, 243, 551, 34, 159, 3,
+# 464, 200, 77, 152, 201, 97, 129, 8, 577, 337, 532, 47,
+# 155, 164, 217, 34, 135, 11, 335, 132, 528, 480, 255, 246,
+# 12, 479, 285, 166, 575, 572, 828, 693, 434, 145, 66, 129,
+# 573, 256, 41, 325, 71, 359, 198, 182, 210, 18, 633, 393,
+# 13, 8, 305, 69, 24, 3, 19, 22, 277, 16, 405, 205,
+# 320, 1, 149, 373, 41, 112, 559, 445, 145, 409, 715, 267,
+# 173, 79, 663, 348, 292, 64, 354, 426, 61, 34, 206, 316,
+# 479, 246, 323, 272, 274, 154, 111, 150, 50, 56, 129, 82,
+# 549, 45, 114, 24, 40, 163, 701, 23, 190, 114, 646, 51,
+# 142, 55, 214, 460, 377, 298, 84, 292, 160, 6, 2, 8,
+# 47, 466, 863, 233, 107, 352, 380, 382, 542, 271, 925, 505,
+# 51, 50, 332, 159, 9, 359, 771, 8, 814, 461, 125, 152,
+# 75, 266, 143, 368, 95, 16, 18, 71, 234, 197, 50, 398,
+# 16, 73, 44, 2, 860, 453, 5, 30, 219, 67, 573, 39,
+# 153, 361, 102, 489, 234, 357, 252, 73, 100, 371, 507, 34,
+# 15, 86, 88, 44, 26, 216, 113, 94, 24, 416, 198, 123,
+# 957, 94, 92, 263, 119, 198, 762, 312, 8, 40, 135, 51,
+# 130, 4, 600, 317, 302, 578, 299, 184, 163, 332, 50, 356,
+# 376, 339, 45, 585, 144, 66, 823, 666, 708, 83, 233, 322,
+# 1, 141, 52, 427, 489, 275, 125, 111, 1, 16, 785, 519,
+# 346, 374, 323, 149, 127, 565, 217, 149, 634, 537, 592, 69,
+# 668, 24, 19, 177, 7, 365, 530, 794, 84, 757, 632, 293,
+# 681, 69, 112, 71, 193, 430, 28, 224, 276, 486, 483, 144,
+# 20, 521, 414, 512, 458, 51, 125, 612, 166, 357, 120, 532,
+# 91, 344, 81, 331, 58, 63, 837, 628, 100, 305, 87, 171,
+# 176, 429, 757, 186, 718, 629, 225, 48, 363, 2, 274, 227,
+# 74, 554, 28, 123, 653, 466, 859, 750, 33, 135, 18, 185,
+# 24, 258, 52, 581, 426, 277, 109, 16, 144, 11, 139, 0,
+# 153, 663, 6, 74, 140, 328, 209, 389, 25, 576, 16, 422,
+# 503, 381, 513, 85, 287, 272, 271, 364, 5, 43, 17, 7,
+# 646, 429, 582, 19, 265, 252, 18, 63, 212, 123, 724, 119,
+# 188, 423, 395, 169, 13, 139, 407, 76, 142, 123, 763, 170,
+# 250, 40, 18, 21, 50, 312, 76, 532, 213, 80, 148, 147,
+# 161, 24, 201, 680, 42, 11, 98, 1, 249, 185, 69, 447,
+# 49, 313, 218, 54, 610, 371, 215, 212, 555, 739, 23, 741,
+# 5, 20, 115, 13, 311, 79, 57, 99, 208, 219, 200, 4,
+# 53, 326, 605, 7, 45, 50, 265, 84, 521, 779, 121, 142,
+# 274, 89, 52, 388, 201, 406, 17, 442, 84, 192, 606, 857,
+# 640, 140, 99, 407, 63, 688, 387, 222, 36, 255, 311, 459,
+# 591, 112, 344, 114, 234, 563, 426, 68, 337, 82, 19, 8,
+# 221, 374, 18, 141, 408, 49, 391, 123, 847, 409, 537, 809,
+# 21, 138, 213, 250, 11, 216, 21, 33, 263, 551, 993, 496,
+# 34, 2, 153, 261, 257, 74, 431, 401, 755, 101, 94, 593,
+# 782, 366, 192, 11);
+
+my @HT = sort { $a->[0] <=> $b->[0] } map { [ $H[$_], $T[$_] ] } 0..$#H;
+
+# Procedural
+
+sub OL_procedural {
+ my (@HTP, @AP) = @_;
+ while (@HTP) {
+ my $per = shift @HTP;
+ my ($idx, $und, $tgt) = (0, 0, $per->[1]);
+ while ($und <= $tgt) {
+ $und += 1 unless defined $AP[$idx];
+ $idx += 1 if $und <= $tgt;
+ }
+ $idx += 1 if defined $AP[$idx];
+ $AP[$idx] = $per->[0];
+ }
+ return @AP;
+}
+
+# Recursive
+
+sub OL_recursive {
+ my (@HTR, ) = @_;
+ sub slot_by_smallest {
+ my ($smallest, @bigger, @list) = @_;
+ @list = slot_by_smallest(@bigger) if @bigger;
+ splice @list, $smallest->[1], 0, $smallest->[0];
+ return @list;
+ }
+ return slot_by_smallest @HTR;
+}
+
+my @AP = OL_procedural @HT;
+warn "No solution to height ordering." unless @AP;
+
+my @AR = OL_recursive @HT;
+warn "No solution to height ordering." unless @AR;