Department numbers: Difference between revisions

From Rosetta Code
Content added Content deleted
(→‎{{header|Perl}}: added zkl)
(→‎{{header|zkl}}: added solution)
Line 53: Line 53:


=={{header|zkl}}==
=={{header|zkl}}==
<lang>Utils.Helpers.pickNFrom(3,[1..7].walk()) // 35 combos
<lang zkl>Utils.Helpers.pickNFrom(3,[1..7].walk()) // 35 combos
.filter(fcn(numbers){ numbers.sum(0)==12 }) // which all sum to 12
.filter(fcn(numbers){ numbers.sum(0)==12 }) // which all sum to 12 (==5)
.filter("apply","isEven") // at least one number is even
.filter("apply","isEven") // at least one number is even
.println();</lang>
.println();</lang>
{{output}}
{{output}}
<pre>
<pre>
L(L(1,4,7),L(1,5,6),L(2,3,7),L(2,4,6),L(3,4,5))
L(L(1,4,7),L(1,5,6),L(2,3,7),L(2,4,6),L(3,4,5))
</pre>
For a table with repeated solutions:
<lang zkl>ns:=Utils.Helpers.pickNFrom(3,[1..7].walk()) // 35 combos
.filter(fcn(numbers){ numbers.sum(0)==12 }) // which all sum to 12 (==5)
.filter("apply","isEven") // at least one number is even
.pump(List,Utils.Helpers.permute) // expand 5 results --> list of lists
.flatten() // ( (),()..) --> ()
.filter(fcn([(p,_,_)]){ p.isEven }); // with even first number
println("Police Fire Sanitation");
foreach pfs in (ns){ "%d\t%d\t%d".fmt(pfs.xplode()).println() }</lang>
{{out}}
<pre>
Police Fire Sanitation
4 7 1
4 1 7
6 1 5
6 5 1
2 3 7
2 7 3
2 4 6
2 6 4
6 2 4
6 4 2
4 6 2
4 2 6
4 5 3
4 3 5
</pre>
</pre>

Revision as of 18:23, 22 May 2017

Task
Department numbers
You are encouraged to solve this task according to the task description, using any language you may know.

There is a highly organized city that has decided to assign a number to each of their departments. Police, Sanitation and Fire Department.

Each Department can have a number between 1 and 7.
The 3 numbers have to be different and have to add up to the number 12.
For some reason the Chief of the Police Department doesn't like odd numbers and wants to have an even number for his department.

Write a programm which outputs all valid combinations.


Possible Output:

1 2 9
5 3 4


Perl

<lang Perl>

  1. !/usr/bin/perl

my @even_numbers;

for (1..7) {

 if ( $_ % 2 == 0)
 {
   push @even_numbers, $_;
 }

}

print "Police\tFire\tSanitation\n";

foreach my $police_number (@even_numbers) {

 for my $fire_number (1..7)
 {
   for my $sanitation_number (1..7)
   {
     if ( $police_number + $fire_number + $sanitation_number == 12 && 
          $police_number != $fire_number && 
          $fire_number != $sanitation_number && 
          $sanitation_number != $police_number)
     {
       print "$police_number\t$fire_number\t$sanitation_number\n";
     }
   }
 }	

} </lang>

zkl

<lang zkl>Utils.Helpers.pickNFrom(3,[1..7].walk()) // 35 combos .filter(fcn(numbers){ numbers.sum(0)==12 }) // which all sum to 12 (==5) .filter("apply","isEven") // at least one number is even .println();</lang>

Output:
L(L(1,4,7),L(1,5,6),L(2,3,7),L(2,4,6),L(3,4,5))

For a table with repeated solutions: <lang zkl>ns:=Utils.Helpers.pickNFrom(3,[1..7].walk()) // 35 combos

 .filter(fcn(numbers){ numbers.sum(0)==12 })  // which all sum to 12 (==5)
 .filter("apply","isEven")		// at least one number is even
 .pump(List,Utils.Helpers.permute)	// expand 5 results --> list of lists
 .flatten()				// ( (),()..) --> ()
 .filter(fcn([(p,_,_)]){ p.isEven });	// with even first number

println("Police Fire Sanitation"); foreach pfs in (ns){ "%d\t%d\t%d".fmt(pfs.xplode()).println() }</lang>

Output:
Police  Fire  Sanitation
4	7	1
4	1	7
6	1	5
6	5	1
2	3	7
2	7	3
2	4	6
2	6	4
6	2	4
6	4	2
4	6	2
4	2	6
4	5	3
4	3	5