Eight coins for the fair king












21














This is a "counterpart" of another puzzle, Eight coins for the fair king on Puzzling.SE.



You can read the above puzzle for the background. The details about this puzzle are as follows.



A set of 8 kinds of coins of different values are created, the king wants you to find out the maximum N such that any number of price from 0 to N can be paid with a combination no more than 8 coins and without charges.



For example, (taken from Glorfindel's answer). If a set of coins of values 1, 2, 5, 13, 34, 89, 233, 610 are given, your program should output 1596, because every number between 0 and 1596 (inclusive) can be represented by the sum of no more than 8 numbers from the given list (numbers may repeat), while 1597 cannot be represented in that way.



In a mathematical way, if the input is a set S consisting of 8 positive integers, the desired output N satisfies that for any number n between 0 and N, there exists x1, x2, x3, ..., x8 such that



$$x_1 + x_2 + ... + x_8 = n quadtextrm{and}quad x_1, x_2, ...,x_8 in {0} cup S$$



Your goal is to write a program, a function, or a snippet that takes 8 numbers as input, and output the maximum N as described above.



Rules:




  • Flexible I/O allowed, so your program can take the input in any form that's best suitable. You may assume that the input numbers are sorted in the way that best suits your program.


    • Please state it in your answer if your program depends on input order



  • Input is a set of 8 different, positive integers (no zeros). The output is one non-negative integer.


    • In case there's no 1 in the input set, your program should output 0 because any number from 0 to 0 satisfies the requirement.

    • In the case of invalid input (the set contains zero, negative or duplicate numbers), your program can do anything.



  • Standard loopholes are forbidden.

  • Your program should run within a few minutes on a modern computer.


Test cases (mostly taken from the answers under the linked question on Puzzling):



[1, 2, 3, 4, 5, 6, 7, 8] => 64
[2, 3, 4, 5, 6, 7, 8, 9] => 0
[1, 3, 4, 5, 6, 7, 8, 9] => 72
[1, 2, 5, 13, 34, 89, 233, 610] => 1596
[1, 5, 16, 51, 130, 332, 471, 1082] => 2721
[1, 6, 20, 75, 175, 474, 756, 785] => 3356


This is a code-golf, so the shortest program or snippet in each language wins!










share|improve this question




















  • 1




    Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
    – Mr. Xcoder
    Dec 25 '18 at 11:42










  • Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
    – Luis Mendo
    Dec 25 '18 at 11:43








  • 1




    @iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
    – Luis Mendo
    Dec 25 '18 at 11:48








  • 1




    Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
    – nimi
    Dec 25 '18 at 12:01








  • 1




    @Arnauld Clarified
    – iBug
    Dec 26 '18 at 1:34
















21














This is a "counterpart" of another puzzle, Eight coins for the fair king on Puzzling.SE.



You can read the above puzzle for the background. The details about this puzzle are as follows.



A set of 8 kinds of coins of different values are created, the king wants you to find out the maximum N such that any number of price from 0 to N can be paid with a combination no more than 8 coins and without charges.



For example, (taken from Glorfindel's answer). If a set of coins of values 1, 2, 5, 13, 34, 89, 233, 610 are given, your program should output 1596, because every number between 0 and 1596 (inclusive) can be represented by the sum of no more than 8 numbers from the given list (numbers may repeat), while 1597 cannot be represented in that way.



In a mathematical way, if the input is a set S consisting of 8 positive integers, the desired output N satisfies that for any number n between 0 and N, there exists x1, x2, x3, ..., x8 such that



$$x_1 + x_2 + ... + x_8 = n quadtextrm{and}quad x_1, x_2, ...,x_8 in {0} cup S$$



Your goal is to write a program, a function, or a snippet that takes 8 numbers as input, and output the maximum N as described above.



Rules:




  • Flexible I/O allowed, so your program can take the input in any form that's best suitable. You may assume that the input numbers are sorted in the way that best suits your program.


    • Please state it in your answer if your program depends on input order



  • Input is a set of 8 different, positive integers (no zeros). The output is one non-negative integer.


    • In case there's no 1 in the input set, your program should output 0 because any number from 0 to 0 satisfies the requirement.

    • In the case of invalid input (the set contains zero, negative or duplicate numbers), your program can do anything.



  • Standard loopholes are forbidden.

  • Your program should run within a few minutes on a modern computer.


Test cases (mostly taken from the answers under the linked question on Puzzling):



[1, 2, 3, 4, 5, 6, 7, 8] => 64
[2, 3, 4, 5, 6, 7, 8, 9] => 0
[1, 3, 4, 5, 6, 7, 8, 9] => 72
[1, 2, 5, 13, 34, 89, 233, 610] => 1596
[1, 5, 16, 51, 130, 332, 471, 1082] => 2721
[1, 6, 20, 75, 175, 474, 756, 785] => 3356


This is a code-golf, so the shortest program or snippet in each language wins!










share|improve this question




















  • 1




    Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
    – Mr. Xcoder
    Dec 25 '18 at 11:42










  • Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
    – Luis Mendo
    Dec 25 '18 at 11:43








  • 1




    @iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
    – Luis Mendo
    Dec 25 '18 at 11:48








  • 1




    Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
    – nimi
    Dec 25 '18 at 12:01








  • 1




    @Arnauld Clarified
    – iBug
    Dec 26 '18 at 1:34














21












21








21


3





This is a "counterpart" of another puzzle, Eight coins for the fair king on Puzzling.SE.



You can read the above puzzle for the background. The details about this puzzle are as follows.



A set of 8 kinds of coins of different values are created, the king wants you to find out the maximum N such that any number of price from 0 to N can be paid with a combination no more than 8 coins and without charges.



For example, (taken from Glorfindel's answer). If a set of coins of values 1, 2, 5, 13, 34, 89, 233, 610 are given, your program should output 1596, because every number between 0 and 1596 (inclusive) can be represented by the sum of no more than 8 numbers from the given list (numbers may repeat), while 1597 cannot be represented in that way.



In a mathematical way, if the input is a set S consisting of 8 positive integers, the desired output N satisfies that for any number n between 0 and N, there exists x1, x2, x3, ..., x8 such that



$$x_1 + x_2 + ... + x_8 = n quadtextrm{and}quad x_1, x_2, ...,x_8 in {0} cup S$$



Your goal is to write a program, a function, or a snippet that takes 8 numbers as input, and output the maximum N as described above.



Rules:




  • Flexible I/O allowed, so your program can take the input in any form that's best suitable. You may assume that the input numbers are sorted in the way that best suits your program.


    • Please state it in your answer if your program depends on input order



  • Input is a set of 8 different, positive integers (no zeros). The output is one non-negative integer.


    • In case there's no 1 in the input set, your program should output 0 because any number from 0 to 0 satisfies the requirement.

    • In the case of invalid input (the set contains zero, negative or duplicate numbers), your program can do anything.



  • Standard loopholes are forbidden.

  • Your program should run within a few minutes on a modern computer.


Test cases (mostly taken from the answers under the linked question on Puzzling):



[1, 2, 3, 4, 5, 6, 7, 8] => 64
[2, 3, 4, 5, 6, 7, 8, 9] => 0
[1, 3, 4, 5, 6, 7, 8, 9] => 72
[1, 2, 5, 13, 34, 89, 233, 610] => 1596
[1, 5, 16, 51, 130, 332, 471, 1082] => 2721
[1, 6, 20, 75, 175, 474, 756, 785] => 3356


This is a code-golf, so the shortest program or snippet in each language wins!










share|improve this question















This is a "counterpart" of another puzzle, Eight coins for the fair king on Puzzling.SE.



You can read the above puzzle for the background. The details about this puzzle are as follows.



A set of 8 kinds of coins of different values are created, the king wants you to find out the maximum N such that any number of price from 0 to N can be paid with a combination no more than 8 coins and without charges.



For example, (taken from Glorfindel's answer). If a set of coins of values 1, 2, 5, 13, 34, 89, 233, 610 are given, your program should output 1596, because every number between 0 and 1596 (inclusive) can be represented by the sum of no more than 8 numbers from the given list (numbers may repeat), while 1597 cannot be represented in that way.



In a mathematical way, if the input is a set S consisting of 8 positive integers, the desired output N satisfies that for any number n between 0 and N, there exists x1, x2, x3, ..., x8 such that



$$x_1 + x_2 + ... + x_8 = n quadtextrm{and}quad x_1, x_2, ...,x_8 in {0} cup S$$



Your goal is to write a program, a function, or a snippet that takes 8 numbers as input, and output the maximum N as described above.



Rules:




  • Flexible I/O allowed, so your program can take the input in any form that's best suitable. You may assume that the input numbers are sorted in the way that best suits your program.


    • Please state it in your answer if your program depends on input order



  • Input is a set of 8 different, positive integers (no zeros). The output is one non-negative integer.


    • In case there's no 1 in the input set, your program should output 0 because any number from 0 to 0 satisfies the requirement.

    • In the case of invalid input (the set contains zero, negative or duplicate numbers), your program can do anything.



  • Standard loopholes are forbidden.

  • Your program should run within a few minutes on a modern computer.


Test cases (mostly taken from the answers under the linked question on Puzzling):



[1, 2, 3, 4, 5, 6, 7, 8] => 64
[2, 3, 4, 5, 6, 7, 8, 9] => 0
[1, 3, 4, 5, 6, 7, 8, 9] => 72
[1, 2, 5, 13, 34, 89, 233, 610] => 1596
[1, 5, 16, 51, 130, 332, 471, 1082] => 2721
[1, 6, 20, 75, 175, 474, 756, 785] => 3356


This is a code-golf, so the shortest program or snippet in each language wins!







code-golf number-theory integer






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Dec 26 '18 at 11:43

























asked Dec 25 '18 at 10:15









iBug

1,377731




1,377731








  • 1




    Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
    – Mr. Xcoder
    Dec 25 '18 at 11:42










  • Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
    – Luis Mendo
    Dec 25 '18 at 11:43








  • 1




    @iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
    – Luis Mendo
    Dec 25 '18 at 11:48








  • 1




    Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
    – nimi
    Dec 25 '18 at 12:01








  • 1




    @Arnauld Clarified
    – iBug
    Dec 26 '18 at 1:34














  • 1




    Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
    – Mr. Xcoder
    Dec 25 '18 at 11:42










  • Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
    – Luis Mendo
    Dec 25 '18 at 11:43








  • 1




    @iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
    – Luis Mendo
    Dec 25 '18 at 11:48








  • 1




    Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
    – nimi
    Dec 25 '18 at 12:01








  • 1




    @Arnauld Clarified
    – iBug
    Dec 26 '18 at 1:34








1




1




Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
– Mr. Xcoder
Dec 25 '18 at 11:42




Nice puzzle, but I personally think that some more test cases would be helpful in order to test our submissions.
– Mr. Xcoder
Dec 25 '18 at 11:42












Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
– Luis Mendo
Dec 25 '18 at 11:43






Wouldn't it be better to make input size a parameter? Brute force approaches will struggle with 8
– Luis Mendo
Dec 25 '18 at 11:43






1




1




@iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
– Luis Mendo
Dec 25 '18 at 11:48






@iBug Then the usual rule is something like "submissions shoud run within a minute in a modern computer". It's fuzzy, but usually good enough, because the difference between brute force and efficient approaches is very large
– Luis Mendo
Dec 25 '18 at 11:48






1




1




Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
– nimi
Dec 25 '18 at 12:01






Brute force is still possible with your time limit of "a few minutes". A slightly modified version of my answer runs the last test case in 1m20s on my 7 year old laptop.
– nimi
Dec 25 '18 at 12:01






1




1




@Arnauld Clarified
– iBug
Dec 26 '18 at 1:34




@Arnauld Clarified
– iBug
Dec 26 '18 at 1:34










12 Answers
12






active

oldest

votes


















14















Python 3, 113 62 bytes





for i in[1]*3:x|={a+b for a in x for b in x}
while{i+1}&x:i+=1


Here x is the input as a set of ints, and i is the output.



Try it online!



(Thanks: Erik the Outgolfer, Mr. Xcoder, Lynn)






share|improve this answer



















  • 1




    96 bytes.
    – Erik the Outgolfer
    Dec 25 '18 at 20:16










  • x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
    – Mr. Xcoder
    Dec 25 '18 at 23:21












  • 78 bytes in Python 2.
    – Lynn
    Dec 28 '18 at 15:04



















9















Jelly, 12 bytes



œċⱮ8Ẏ§ṢQJƑƤS


Try it online!



Takes on average ~3.7 seconds to run all test cases on TIO on my phone, so surprisingly it is quite fast.



Explanation



œċⱮ8Ẏ§ṢQJƑƤS     Monadic link / Full program.
Ɱ8 Promote 8 to [1 ... 8] and for each value k:
œċ Generate all combinations of k elements from the list.
Ẏ§ Tighten, then sum. Flatten to a 2D list then sum each.
ṢQ Sort the result and remove equal entries.
JƑƤ For each prefix of this list, return 1 if it is equal to its length range, 0 otherwise.
S Finally, sum the result (counts the 1's which is equivalent to what is being asked).





share|improve this answer































    7














    Haskell, 56 50 bytes



    g c=[x|x<-[1..],all((/=x).sum)$mapM(0:)$c<$c]!!0-1


    Try it online!



    A brute force approach. Add 0 to the list of coins and try all combinations of 8 picks. Find the first number n that is not equal to the sum of any of the picks and return n-1.



    Takes about 5m30s for [1, 2, 5, 13, 34, 89, 233, 610] on my 7 year old laptop hardware.



    Edit: -6 bytes thanks to @Ørjan Johansen



    An even shorter version (-2 bytes, again thanks to @Ørjan Johansen) is



    Haskell, 48 bytes



    g c=[x|x<-[1..],all((/=x).sum)$mapM(:0:c)c]!!0-1


    but it uses significantly more memory and runs into heavy paging on my machine and does not finish "within a few minutes".






    share|improve this answer



















    • 1




      You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
      – Ørjan Johansen
      Dec 25 '18 at 20:06



















    4















    Jelly, 9 bytes



    Żœċ8§ḟ’$Ṃ


    Try it online!



    How it works



    Żœċ8§ḟ’$Ṃ  Main link. Argument: A (array)

    Ż Prepend a 0 to A.
    œċ8 Take all combinations of length 8, with repetitions.
    § Take the sum of each combination.
    $ Combine the two links to the left into a monadic chain.
    ’ Decrement all sums.
    ḟ Filterfalse; keep only sums that do not appear in the decremented sums.
    Ṃ Take the minimum.





    share|improve this answer

















    • 2




      Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
      – Dennis
      Dec 26 '18 at 4:02



















    4















    Wolfram Language (Mathematica), 53 bytes



    LengthWhile[CoefficientList[(1+Tr[x^#])^8,x],#>0&]-1&


    Try it online!






    share|improve this answer































      4














      JavaScript (ES6),  100 88 80  76 bytes



      This is essentially a brute-force search, but enhanced with pruning to speed it up. The average execution time for the test cases is close to 1 second on TIO.



      Assumes that the input array is sorted from highest to lowest.





      a=>[...Array(a[0]*9)].findIndex(g=(i=8,s)=>s*i>0?a.every(x=>g(i-1,s-x)):s)-1


      Try it online!



      Commented



      a =>                      // a = input array
      [...Array(a[0] * 9)] // create an array of 9 * max(a) entries
      .findIndex( // find the position of the first truthy result
      g = (i = 8, s) => // g = recursive function taking a counter i, initialized to 8
      // and a sum s, initialized to the position in the above array
      s * i > 0 ? // if s is positive and i is not equal to 0:
      a.every(x => // for each value x in a:
      g(i - 1, s - x) // do a recursive call with i - 1 and s - x
      ) // end of every()
      : // else:
      s // yield s (s = 0 means success and makes findIndex go on)
      ) - 1 // end of findIndex(); decrement the result





      share|improve this answer































        3















        Python 2, 145 bytes





        from itertools import*
        x=set(map(sum,reduce(chain,map(combinations_with_replacement,[input()]*9,range(9)))))
        print~-min(set(range(1,max(x)+2))-x)


        Try it online!






        share|improve this answer





























          3















          Pari/GP, 57 bytes



          a->n=-1;while(polcoeff((1+sum(i=1,8,x^a[i]))^8,n++),);n-1


          Try it online!






          share|improve this answer





















          • is this using generating function?
            – don bright
            Jan 2 at 0:03






          • 1




            @donbright Yes.
            – alephalpha
            2 days ago






          • 1




            that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
            – don bright
            2 days ago



















          2















          Python 2, 125 115 111 bytes





          lambda c:sum(i==j for i,j in enumerate(sorted(set(map(sum,product([0]+c,repeat=8))))))-1
          from itertools import*


          Try it online!



          Expects a list of integers as input.



          Explanation:



          # an anonymous function
          lambda c:
          # get all length-8 combinations of values, from (0,0,0,0,0,0,0,0) to (8,8,8,8,8,8,8,8)
          # zero is added to ensure that combinations of fewer than 8 coins are represented Ex:(1,0,0,0,0,0,0,0)
          product([0]+c,repeat=8)
          # for each combination, sum the values
          map(sum,.......................)
          # get unique values, then sort them smallest to largest
          sorted(set(................................))
          # for each index, value pair, return if the index is equal to the value
          i==j for i,j in enumerate(.............................................)
          # in Python arithmetic, False is 0 and True is 1. So, count how many items match their index.
          # Since zero was added to the list, there will always be one extra match (0==0). So offset by one.
          sum(........................................................................)-1
          from itertools import*





          share|improve this answer































            2














            Perl6, 65 63 41 bytes (39 chars)





            {@_=(0,|@_)X+(0,|@_)for ^3;($_ if $_==$++for @_.sort.unique)-1}


            Try it online!



            This is an anonymous block that gets passed its data as an array. The (0,|@_) is a quick way to add a 0 to @_, and even though it's done twice, it's still a bit shorter than @_.push: 0; which would then need spaces after the _. This is a brute force approach that cheeses a bit on the fact that it's 8 combinations. After cross adding, an anonymous list is created for sequential values. With math operators, lists evaluate to their length, so the -1 pulls double duty: accounting for the 0 and coercing to Int.



            This can take its sweet time, but by changing one or both (0,|@_) to (0,|@_.unique) before the first for it can be sped up considerably. That adds +7 (runtime <60s) or +14 (runtime <10s) to the score if you feel the first is too slow (I did this for the linked code to avoid timeouts after 60 seconds).



            Edit: JoKing in the comments improved it (same idea, cross add, then return the last consecutive result) to an astonishing 39 chars (41 bytes):





            {(@_=@_ X+0,|@_)xx 1;first *+1∉@_,0..*}


            Try it online!



            The final tabulation doesn't need a 0, saving a few bytes by only needing to add 0 in once. The xx 3 mimics the for loop (still cheeses on the coins being a power of 2). The first sub returns the first number in the infinite list 0..* (^Inf is possible too, but doesn't save space) whose +1 is not a member of the cross added list. Like mine, it's slow, so add +7 for a unique after the first equals if you feel it's too slow for guidelines.






            share|improve this answer



















            • 1




              48 bytes. Technically, the unique is not needed, but it speeds it up a lot
              – Jo King
              Dec 28 '18 at 7:14










            • @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
              – guifa
              Dec 28 '18 at 15:17



















            1















            JavaScript (Node.js), 171 145 115 bytes





            f=(s,n=3)=>n?f(s=new Set(a=[0,...s]),n-1,a.map(m=>a.map(n=>s.add(m+n)))):Math.min(...[...s].filter(m=>!s.has(m+1)))


            Try it online! Port of @Mark's Python 3 answer. 108 bytes in Firefox 30-57:



            f=(s,n=3)=>n?f(new Set((for(n of s=[0,...s])for(m of s)n+m)),n-1):Math.min(...[...s].filter(m=>!s.has(m+1)))





            share|improve this answer































              0















              Clean, 161 bytes



              import StdEnv,Data.List
              $l=:[1:_]#k=sort(nub(map sum(iter 8(concatMap([h:t]=[[e,h:t]\e<-[0:l]|e>=h]))[[0]])))
              =length(takeWhile((>=)1)(zipWith(-)(tl k)k))
              $_=0


              Try it online!






              share|improve this answer





















                Your Answer





                StackExchange.ifUsing("editor", function () {
                return StackExchange.using("mathjaxEditing", function () {
                StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
                StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
                });
                });
                }, "mathjax-editing");

                StackExchange.ifUsing("editor", function () {
                StackExchange.using("externalEditor", function () {
                StackExchange.using("snippets", function () {
                StackExchange.snippets.init();
                });
                });
                }, "code-snippets");

                StackExchange.ready(function() {
                var channelOptions = {
                tags: "".split(" "),
                id: "200"
                };
                initTagRenderer("".split(" "), "".split(" "), channelOptions);

                StackExchange.using("externalEditor", function() {
                // Have to fire editor after snippets, if snippets enabled
                if (StackExchange.settings.snippets.snippetsEnabled) {
                StackExchange.using("snippets", function() {
                createEditor();
                });
                }
                else {
                createEditor();
                }
                });

                function createEditor() {
                StackExchange.prepareEditor({
                heartbeatType: 'answer',
                autoActivateHeartbeat: false,
                convertImagesToLinks: false,
                noModals: true,
                showLowRepImageUploadWarning: true,
                reputationToPostImages: null,
                bindNavPrevention: true,
                postfix: "",
                imageUploader: {
                brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                allowUrls: true
                },
                onDemand: true,
                discardSelector: ".discard-answer"
                ,immediatelyShowMarkdownHelp:true
                });


                }
                });














                draft saved

                draft discarded


















                StackExchange.ready(
                function () {
                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodegolf.stackexchange.com%2fquestions%2f178015%2feight-coins-for-the-fair-king%23new-answer', 'question_page');
                }
                );

                Post as a guest















                Required, but never shown

























                12 Answers
                12






                active

                oldest

                votes








                12 Answers
                12






                active

                oldest

                votes









                active

                oldest

                votes






                active

                oldest

                votes









                14















                Python 3, 113 62 bytes





                for i in[1]*3:x|={a+b for a in x for b in x}
                while{i+1}&x:i+=1


                Here x is the input as a set of ints, and i is the output.



                Try it online!



                (Thanks: Erik the Outgolfer, Mr. Xcoder, Lynn)






                share|improve this answer



















                • 1




                  96 bytes.
                  – Erik the Outgolfer
                  Dec 25 '18 at 20:16










                • x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                  – Mr. Xcoder
                  Dec 25 '18 at 23:21












                • 78 bytes in Python 2.
                  – Lynn
                  Dec 28 '18 at 15:04
















                14















                Python 3, 113 62 bytes





                for i in[1]*3:x|={a+b for a in x for b in x}
                while{i+1}&x:i+=1


                Here x is the input as a set of ints, and i is the output.



                Try it online!



                (Thanks: Erik the Outgolfer, Mr. Xcoder, Lynn)






                share|improve this answer



















                • 1




                  96 bytes.
                  – Erik the Outgolfer
                  Dec 25 '18 at 20:16










                • x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                  – Mr. Xcoder
                  Dec 25 '18 at 23:21












                • 78 bytes in Python 2.
                  – Lynn
                  Dec 28 '18 at 15:04














                14












                14








                14







                Python 3, 113 62 bytes





                for i in[1]*3:x|={a+b for a in x for b in x}
                while{i+1}&x:i+=1


                Here x is the input as a set of ints, and i is the output.



                Try it online!



                (Thanks: Erik the Outgolfer, Mr. Xcoder, Lynn)






                share|improve this answer















                Python 3, 113 62 bytes





                for i in[1]*3:x|={a+b for a in x for b in x}
                while{i+1}&x:i+=1


                Here x is the input as a set of ints, and i is the output.



                Try it online!



                (Thanks: Erik the Outgolfer, Mr. Xcoder, Lynn)







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Dec 29 '18 at 15:37

























                answered Dec 25 '18 at 19:27









                Mark

                2413




                2413








                • 1




                  96 bytes.
                  – Erik the Outgolfer
                  Dec 25 '18 at 20:16










                • x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                  – Mr. Xcoder
                  Dec 25 '18 at 23:21












                • 78 bytes in Python 2.
                  – Lynn
                  Dec 28 '18 at 15:04














                • 1




                  96 bytes.
                  – Erik the Outgolfer
                  Dec 25 '18 at 20:16










                • x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                  – Mr. Xcoder
                  Dec 25 '18 at 23:21












                • 78 bytes in Python 2.
                  – Lynn
                  Dec 28 '18 at 15:04








                1




                1




                96 bytes.
                – Erik the Outgolfer
                Dec 25 '18 at 20:16




                96 bytes.
                – Erik the Outgolfer
                Dec 25 '18 at 20:16












                x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                – Mr. Xcoder
                Dec 25 '18 at 23:21






                x=0,*x saves 1 byte. Better yet, x+=0, saves 2.
                – Mr. Xcoder
                Dec 25 '18 at 23:21














                78 bytes in Python 2.
                – Lynn
                Dec 28 '18 at 15:04




                78 bytes in Python 2.
                – Lynn
                Dec 28 '18 at 15:04











                9















                Jelly, 12 bytes



                œċⱮ8Ẏ§ṢQJƑƤS


                Try it online!



                Takes on average ~3.7 seconds to run all test cases on TIO on my phone, so surprisingly it is quite fast.



                Explanation



                œċⱮ8Ẏ§ṢQJƑƤS     Monadic link / Full program.
                Ɱ8 Promote 8 to [1 ... 8] and for each value k:
                œċ Generate all combinations of k elements from the list.
                Ẏ§ Tighten, then sum. Flatten to a 2D list then sum each.
                ṢQ Sort the result and remove equal entries.
                JƑƤ For each prefix of this list, return 1 if it is equal to its length range, 0 otherwise.
                S Finally, sum the result (counts the 1's which is equivalent to what is being asked).





                share|improve this answer




























                  9















                  Jelly, 12 bytes



                  œċⱮ8Ẏ§ṢQJƑƤS


                  Try it online!



                  Takes on average ~3.7 seconds to run all test cases on TIO on my phone, so surprisingly it is quite fast.



                  Explanation



                  œċⱮ8Ẏ§ṢQJƑƤS     Monadic link / Full program.
                  Ɱ8 Promote 8 to [1 ... 8] and for each value k:
                  œċ Generate all combinations of k elements from the list.
                  Ẏ§ Tighten, then sum. Flatten to a 2D list then sum each.
                  ṢQ Sort the result and remove equal entries.
                  JƑƤ For each prefix of this list, return 1 if it is equal to its length range, 0 otherwise.
                  S Finally, sum the result (counts the 1's which is equivalent to what is being asked).





                  share|improve this answer


























                    9












                    9








                    9







                    Jelly, 12 bytes



                    œċⱮ8Ẏ§ṢQJƑƤS


                    Try it online!



                    Takes on average ~3.7 seconds to run all test cases on TIO on my phone, so surprisingly it is quite fast.



                    Explanation



                    œċⱮ8Ẏ§ṢQJƑƤS     Monadic link / Full program.
                    Ɱ8 Promote 8 to [1 ... 8] and for each value k:
                    œċ Generate all combinations of k elements from the list.
                    Ẏ§ Tighten, then sum. Flatten to a 2D list then sum each.
                    ṢQ Sort the result and remove equal entries.
                    JƑƤ For each prefix of this list, return 1 if it is equal to its length range, 0 otherwise.
                    S Finally, sum the result (counts the 1's which is equivalent to what is being asked).





                    share|improve this answer















                    Jelly, 12 bytes



                    œċⱮ8Ẏ§ṢQJƑƤS


                    Try it online!



                    Takes on average ~3.7 seconds to run all test cases on TIO on my phone, so surprisingly it is quite fast.



                    Explanation



                    œċⱮ8Ẏ§ṢQJƑƤS     Monadic link / Full program.
                    Ɱ8 Promote 8 to [1 ... 8] and for each value k:
                    œċ Generate all combinations of k elements from the list.
                    Ẏ§ Tighten, then sum. Flatten to a 2D list then sum each.
                    ṢQ Sort the result and remove equal entries.
                    JƑƤ For each prefix of this list, return 1 if it is equal to its length range, 0 otherwise.
                    S Finally, sum the result (counts the 1's which is equivalent to what is being asked).






                    share|improve this answer














                    share|improve this answer



                    share|improve this answer








                    edited Dec 25 '18 at 12:24

























                    answered Dec 25 '18 at 12:16









                    Mr. Xcoder

                    31.7k759198




                    31.7k759198























                        7














                        Haskell, 56 50 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(0:)$c<$c]!!0-1


                        Try it online!



                        A brute force approach. Add 0 to the list of coins and try all combinations of 8 picks. Find the first number n that is not equal to the sum of any of the picks and return n-1.



                        Takes about 5m30s for [1, 2, 5, 13, 34, 89, 233, 610] on my 7 year old laptop hardware.



                        Edit: -6 bytes thanks to @Ørjan Johansen



                        An even shorter version (-2 bytes, again thanks to @Ørjan Johansen) is



                        Haskell, 48 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(:0:c)c]!!0-1


                        but it uses significantly more memory and runs into heavy paging on my machine and does not finish "within a few minutes".






                        share|improve this answer



















                        • 1




                          You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                          – Ørjan Johansen
                          Dec 25 '18 at 20:06
















                        7














                        Haskell, 56 50 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(0:)$c<$c]!!0-1


                        Try it online!



                        A brute force approach. Add 0 to the list of coins and try all combinations of 8 picks. Find the first number n that is not equal to the sum of any of the picks and return n-1.



                        Takes about 5m30s for [1, 2, 5, 13, 34, 89, 233, 610] on my 7 year old laptop hardware.



                        Edit: -6 bytes thanks to @Ørjan Johansen



                        An even shorter version (-2 bytes, again thanks to @Ørjan Johansen) is



                        Haskell, 48 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(:0:c)c]!!0-1


                        but it uses significantly more memory and runs into heavy paging on my machine and does not finish "within a few minutes".






                        share|improve this answer



















                        • 1




                          You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                          – Ørjan Johansen
                          Dec 25 '18 at 20:06














                        7












                        7








                        7






                        Haskell, 56 50 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(0:)$c<$c]!!0-1


                        Try it online!



                        A brute force approach. Add 0 to the list of coins and try all combinations of 8 picks. Find the first number n that is not equal to the sum of any of the picks and return n-1.



                        Takes about 5m30s for [1, 2, 5, 13, 34, 89, 233, 610] on my 7 year old laptop hardware.



                        Edit: -6 bytes thanks to @Ørjan Johansen



                        An even shorter version (-2 bytes, again thanks to @Ørjan Johansen) is



                        Haskell, 48 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(:0:c)c]!!0-1


                        but it uses significantly more memory and runs into heavy paging on my machine and does not finish "within a few minutes".






                        share|improve this answer














                        Haskell, 56 50 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(0:)$c<$c]!!0-1


                        Try it online!



                        A brute force approach. Add 0 to the list of coins and try all combinations of 8 picks. Find the first number n that is not equal to the sum of any of the picks and return n-1.



                        Takes about 5m30s for [1, 2, 5, 13, 34, 89, 233, 610] on my 7 year old laptop hardware.



                        Edit: -6 bytes thanks to @Ørjan Johansen



                        An even shorter version (-2 bytes, again thanks to @Ørjan Johansen) is



                        Haskell, 48 bytes



                        g c=[x|x<-[1..],all((/=x).sum)$mapM(:0:c)c]!!0-1


                        but it uses significantly more memory and runs into heavy paging on my machine and does not finish "within a few minutes".







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Dec 25 '18 at 20:50

























                        answered Dec 25 '18 at 11:50









                        nimi

                        31.4k32185




                        31.4k32185








                        • 1




                          You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                          – Ørjan Johansen
                          Dec 25 '18 at 20:06














                        • 1




                          You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                          – Ørjan Johansen
                          Dec 25 '18 at 20:06








                        1




                        1




                        You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                        – Ørjan Johansen
                        Dec 25 '18 at 20:06




                        You can use mapM(0:)$c<$c. (In fact mapM(:0:c)c should work, but times out on TIO for the given test case.)
                        – Ørjan Johansen
                        Dec 25 '18 at 20:06











                        4















                        Jelly, 9 bytes



                        Żœċ8§ḟ’$Ṃ


                        Try it online!



                        How it works



                        Żœċ8§ḟ’$Ṃ  Main link. Argument: A (array)

                        Ż Prepend a 0 to A.
                        œċ8 Take all combinations of length 8, with repetitions.
                        § Take the sum of each combination.
                        $ Combine the two links to the left into a monadic chain.
                        ’ Decrement all sums.
                        ḟ Filterfalse; keep only sums that do not appear in the decremented sums.
                        Ṃ Take the minimum.





                        share|improve this answer

















                        • 2




                          Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                          – Dennis
                          Dec 26 '18 at 4:02
















                        4















                        Jelly, 9 bytes



                        Żœċ8§ḟ’$Ṃ


                        Try it online!



                        How it works



                        Żœċ8§ḟ’$Ṃ  Main link. Argument: A (array)

                        Ż Prepend a 0 to A.
                        œċ8 Take all combinations of length 8, with repetitions.
                        § Take the sum of each combination.
                        $ Combine the two links to the left into a monadic chain.
                        ’ Decrement all sums.
                        ḟ Filterfalse; keep only sums that do not appear in the decremented sums.
                        Ṃ Take the minimum.





                        share|improve this answer

















                        • 2




                          Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                          – Dennis
                          Dec 26 '18 at 4:02














                        4












                        4








                        4







                        Jelly, 9 bytes



                        Żœċ8§ḟ’$Ṃ


                        Try it online!



                        How it works



                        Żœċ8§ḟ’$Ṃ  Main link. Argument: A (array)

                        Ż Prepend a 0 to A.
                        œċ8 Take all combinations of length 8, with repetitions.
                        § Take the sum of each combination.
                        $ Combine the two links to the left into a monadic chain.
                        ’ Decrement all sums.
                        ḟ Filterfalse; keep only sums that do not appear in the decremented sums.
                        Ṃ Take the minimum.





                        share|improve this answer













                        Jelly, 9 bytes



                        Żœċ8§ḟ’$Ṃ


                        Try it online!



                        How it works



                        Żœċ8§ḟ’$Ṃ  Main link. Argument: A (array)

                        Ż Prepend a 0 to A.
                        œċ8 Take all combinations of length 8, with repetitions.
                        § Take the sum of each combination.
                        $ Combine the two links to the left into a monadic chain.
                        ’ Decrement all sums.
                        ḟ Filterfalse; keep only sums that do not appear in the decremented sums.
                        Ṃ Take the minimum.






                        share|improve this answer












                        share|improve this answer



                        share|improve this answer










                        answered Dec 26 '18 at 3:05









                        Dennis

                        186k32297735




                        186k32297735








                        • 2




                          Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                          – Dennis
                          Dec 26 '18 at 4:02














                        • 2




                          Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                          – Dennis
                          Dec 26 '18 at 4:02








                        2




                        2




                        Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                        – Dennis
                        Dec 26 '18 at 4:02




                        Żṗ8§ḟ’$Ṃ saves one byte, but I'm not sure if 8.5 minutes counts as a few.
                        – Dennis
                        Dec 26 '18 at 4:02











                        4















                        Wolfram Language (Mathematica), 53 bytes



                        LengthWhile[CoefficientList[(1+Tr[x^#])^8,x],#>0&]-1&


                        Try it online!






                        share|improve this answer




























                          4















                          Wolfram Language (Mathematica), 53 bytes



                          LengthWhile[CoefficientList[(1+Tr[x^#])^8,x],#>0&]-1&


                          Try it online!






                          share|improve this answer


























                            4












                            4








                            4







                            Wolfram Language (Mathematica), 53 bytes



                            LengthWhile[CoefficientList[(1+Tr[x^#])^8,x],#>0&]-1&


                            Try it online!






                            share|improve this answer















                            Wolfram Language (Mathematica), 53 bytes



                            LengthWhile[CoefficientList[(1+Tr[x^#])^8,x],#>0&]-1&


                            Try it online!







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited Dec 26 '18 at 12:01

























                            answered Dec 26 '18 at 5:35









                            alephalpha

                            21.2k32989




                            21.2k32989























                                4














                                JavaScript (ES6),  100 88 80  76 bytes



                                This is essentially a brute-force search, but enhanced with pruning to speed it up. The average execution time for the test cases is close to 1 second on TIO.



                                Assumes that the input array is sorted from highest to lowest.





                                a=>[...Array(a[0]*9)].findIndex(g=(i=8,s)=>s*i>0?a.every(x=>g(i-1,s-x)):s)-1


                                Try it online!



                                Commented



                                a =>                      // a = input array
                                [...Array(a[0] * 9)] // create an array of 9 * max(a) entries
                                .findIndex( // find the position of the first truthy result
                                g = (i = 8, s) => // g = recursive function taking a counter i, initialized to 8
                                // and a sum s, initialized to the position in the above array
                                s * i > 0 ? // if s is positive and i is not equal to 0:
                                a.every(x => // for each value x in a:
                                g(i - 1, s - x) // do a recursive call with i - 1 and s - x
                                ) // end of every()
                                : // else:
                                s // yield s (s = 0 means success and makes findIndex go on)
                                ) - 1 // end of findIndex(); decrement the result





                                share|improve this answer




























                                  4














                                  JavaScript (ES6),  100 88 80  76 bytes



                                  This is essentially a brute-force search, but enhanced with pruning to speed it up. The average execution time for the test cases is close to 1 second on TIO.



                                  Assumes that the input array is sorted from highest to lowest.





                                  a=>[...Array(a[0]*9)].findIndex(g=(i=8,s)=>s*i>0?a.every(x=>g(i-1,s-x)):s)-1


                                  Try it online!



                                  Commented



                                  a =>                      // a = input array
                                  [...Array(a[0] * 9)] // create an array of 9 * max(a) entries
                                  .findIndex( // find the position of the first truthy result
                                  g = (i = 8, s) => // g = recursive function taking a counter i, initialized to 8
                                  // and a sum s, initialized to the position in the above array
                                  s * i > 0 ? // if s is positive and i is not equal to 0:
                                  a.every(x => // for each value x in a:
                                  g(i - 1, s - x) // do a recursive call with i - 1 and s - x
                                  ) // end of every()
                                  : // else:
                                  s // yield s (s = 0 means success and makes findIndex go on)
                                  ) - 1 // end of findIndex(); decrement the result





                                  share|improve this answer


























                                    4












                                    4








                                    4






                                    JavaScript (ES6),  100 88 80  76 bytes



                                    This is essentially a brute-force search, but enhanced with pruning to speed it up. The average execution time for the test cases is close to 1 second on TIO.



                                    Assumes that the input array is sorted from highest to lowest.





                                    a=>[...Array(a[0]*9)].findIndex(g=(i=8,s)=>s*i>0?a.every(x=>g(i-1,s-x)):s)-1


                                    Try it online!



                                    Commented



                                    a =>                      // a = input array
                                    [...Array(a[0] * 9)] // create an array of 9 * max(a) entries
                                    .findIndex( // find the position of the first truthy result
                                    g = (i = 8, s) => // g = recursive function taking a counter i, initialized to 8
                                    // and a sum s, initialized to the position in the above array
                                    s * i > 0 ? // if s is positive and i is not equal to 0:
                                    a.every(x => // for each value x in a:
                                    g(i - 1, s - x) // do a recursive call with i - 1 and s - x
                                    ) // end of every()
                                    : // else:
                                    s // yield s (s = 0 means success and makes findIndex go on)
                                    ) - 1 // end of findIndex(); decrement the result





                                    share|improve this answer














                                    JavaScript (ES6),  100 88 80  76 bytes



                                    This is essentially a brute-force search, but enhanced with pruning to speed it up. The average execution time for the test cases is close to 1 second on TIO.



                                    Assumes that the input array is sorted from highest to lowest.





                                    a=>[...Array(a[0]*9)].findIndex(g=(i=8,s)=>s*i>0?a.every(x=>g(i-1,s-x)):s)-1


                                    Try it online!



                                    Commented



                                    a =>                      // a = input array
                                    [...Array(a[0] * 9)] // create an array of 9 * max(a) entries
                                    .findIndex( // find the position of the first truthy result
                                    g = (i = 8, s) => // g = recursive function taking a counter i, initialized to 8
                                    // and a sum s, initialized to the position in the above array
                                    s * i > 0 ? // if s is positive and i is not equal to 0:
                                    a.every(x => // for each value x in a:
                                    g(i - 1, s - x) // do a recursive call with i - 1 and s - x
                                    ) // end of every()
                                    : // else:
                                    s // yield s (s = 0 means success and makes findIndex go on)
                                    ) - 1 // end of findIndex(); decrement the result






                                    share|improve this answer














                                    share|improve this answer



                                    share|improve this answer








                                    edited Dec 26 '18 at 12:15

























                                    answered Dec 25 '18 at 20:49









                                    Arnauld

                                    72.6k689305




                                    72.6k689305























                                        3















                                        Python 2, 145 bytes





                                        from itertools import*
                                        x=set(map(sum,reduce(chain,map(combinations_with_replacement,[input()]*9,range(9)))))
                                        print~-min(set(range(1,max(x)+2))-x)


                                        Try it online!






                                        share|improve this answer


























                                          3















                                          Python 2, 145 bytes





                                          from itertools import*
                                          x=set(map(sum,reduce(chain,map(combinations_with_replacement,[input()]*9,range(9)))))
                                          print~-min(set(range(1,max(x)+2))-x)


                                          Try it online!






                                          share|improve this answer
























                                            3












                                            3








                                            3







                                            Python 2, 145 bytes





                                            from itertools import*
                                            x=set(map(sum,reduce(chain,map(combinations_with_replacement,[input()]*9,range(9)))))
                                            print~-min(set(range(1,max(x)+2))-x)


                                            Try it online!






                                            share|improve this answer













                                            Python 2, 145 bytes





                                            from itertools import*
                                            x=set(map(sum,reduce(chain,map(combinations_with_replacement,[input()]*9,range(9)))))
                                            print~-min(set(range(1,max(x)+2))-x)


                                            Try it online!







                                            share|improve this answer












                                            share|improve this answer



                                            share|improve this answer










                                            answered Dec 25 '18 at 13:36









                                            Erik the Outgolfer

                                            31.4k429103




                                            31.4k429103























                                                3















                                                Pari/GP, 57 bytes



                                                a->n=-1;while(polcoeff((1+sum(i=1,8,x^a[i]))^8,n++),);n-1


                                                Try it online!






                                                share|improve this answer





















                                                • is this using generating function?
                                                  – don bright
                                                  Jan 2 at 0:03






                                                • 1




                                                  @donbright Yes.
                                                  – alephalpha
                                                  2 days ago






                                                • 1




                                                  that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                  – don bright
                                                  2 days ago
















                                                3















                                                Pari/GP, 57 bytes



                                                a->n=-1;while(polcoeff((1+sum(i=1,8,x^a[i]))^8,n++),);n-1


                                                Try it online!






                                                share|improve this answer





















                                                • is this using generating function?
                                                  – don bright
                                                  Jan 2 at 0:03






                                                • 1




                                                  @donbright Yes.
                                                  – alephalpha
                                                  2 days ago






                                                • 1




                                                  that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                  – don bright
                                                  2 days ago














                                                3












                                                3








                                                3







                                                Pari/GP, 57 bytes



                                                a->n=-1;while(polcoeff((1+sum(i=1,8,x^a[i]))^8,n++),);n-1


                                                Try it online!






                                                share|improve this answer













                                                Pari/GP, 57 bytes



                                                a->n=-1;while(polcoeff((1+sum(i=1,8,x^a[i]))^8,n++),);n-1


                                                Try it online!







                                                share|improve this answer












                                                share|improve this answer



                                                share|improve this answer










                                                answered Dec 26 '18 at 6:10









                                                alephalpha

                                                21.2k32989




                                                21.2k32989












                                                • is this using generating function?
                                                  – don bright
                                                  Jan 2 at 0:03






                                                • 1




                                                  @donbright Yes.
                                                  – alephalpha
                                                  2 days ago






                                                • 1




                                                  that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                  – don bright
                                                  2 days ago


















                                                • is this using generating function?
                                                  – don bright
                                                  Jan 2 at 0:03






                                                • 1




                                                  @donbright Yes.
                                                  – alephalpha
                                                  2 days ago






                                                • 1




                                                  that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                  – don bright
                                                  2 days ago
















                                                is this using generating function?
                                                – don bright
                                                Jan 2 at 0:03




                                                is this using generating function?
                                                – don bright
                                                Jan 2 at 0:03




                                                1




                                                1




                                                @donbright Yes.
                                                – alephalpha
                                                2 days ago




                                                @donbright Yes.
                                                – alephalpha
                                                2 days ago




                                                1




                                                1




                                                that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                – don bright
                                                2 days ago




                                                that is awesome.. one of the few answers not brute-forcing the solution. alot of languages probably dont have built in polynomial symbolic features. Pari GP is cool.
                                                – don bright
                                                2 days ago











                                                2















                                                Python 2, 125 115 111 bytes





                                                lambda c:sum(i==j for i,j in enumerate(sorted(set(map(sum,product([0]+c,repeat=8))))))-1
                                                from itertools import*


                                                Try it online!



                                                Expects a list of integers as input.



                                                Explanation:



                                                # an anonymous function
                                                lambda c:
                                                # get all length-8 combinations of values, from (0,0,0,0,0,0,0,0) to (8,8,8,8,8,8,8,8)
                                                # zero is added to ensure that combinations of fewer than 8 coins are represented Ex:(1,0,0,0,0,0,0,0)
                                                product([0]+c,repeat=8)
                                                # for each combination, sum the values
                                                map(sum,.......................)
                                                # get unique values, then sort them smallest to largest
                                                sorted(set(................................))
                                                # for each index, value pair, return if the index is equal to the value
                                                i==j for i,j in enumerate(.............................................)
                                                # in Python arithmetic, False is 0 and True is 1. So, count how many items match their index.
                                                # Since zero was added to the list, there will always be one extra match (0==0). So offset by one.
                                                sum(........................................................................)-1
                                                from itertools import*





                                                share|improve this answer




























                                                  2















                                                  Python 2, 125 115 111 bytes





                                                  lambda c:sum(i==j for i,j in enumerate(sorted(set(map(sum,product([0]+c,repeat=8))))))-1
                                                  from itertools import*


                                                  Try it online!



                                                  Expects a list of integers as input.



                                                  Explanation:



                                                  # an anonymous function
                                                  lambda c:
                                                  # get all length-8 combinations of values, from (0,0,0,0,0,0,0,0) to (8,8,8,8,8,8,8,8)
                                                  # zero is added to ensure that combinations of fewer than 8 coins are represented Ex:(1,0,0,0,0,0,0,0)
                                                  product([0]+c,repeat=8)
                                                  # for each combination, sum the values
                                                  map(sum,.......................)
                                                  # get unique values, then sort them smallest to largest
                                                  sorted(set(................................))
                                                  # for each index, value pair, return if the index is equal to the value
                                                  i==j for i,j in enumerate(.............................................)
                                                  # in Python arithmetic, False is 0 and True is 1. So, count how many items match their index.
                                                  # Since zero was added to the list, there will always be one extra match (0==0). So offset by one.
                                                  sum(........................................................................)-1
                                                  from itertools import*





                                                  share|improve this answer


























                                                    2












                                                    2








                                                    2







                                                    Python 2, 125 115 111 bytes





                                                    lambda c:sum(i==j for i,j in enumerate(sorted(set(map(sum,product([0]+c,repeat=8))))))-1
                                                    from itertools import*


                                                    Try it online!



                                                    Expects a list of integers as input.



                                                    Explanation:



                                                    # an anonymous function
                                                    lambda c:
                                                    # get all length-8 combinations of values, from (0,0,0,0,0,0,0,0) to (8,8,8,8,8,8,8,8)
                                                    # zero is added to ensure that combinations of fewer than 8 coins are represented Ex:(1,0,0,0,0,0,0,0)
                                                    product([0]+c,repeat=8)
                                                    # for each combination, sum the values
                                                    map(sum,.......................)
                                                    # get unique values, then sort them smallest to largest
                                                    sorted(set(................................))
                                                    # for each index, value pair, return if the index is equal to the value
                                                    i==j for i,j in enumerate(.............................................)
                                                    # in Python arithmetic, False is 0 and True is 1. So, count how many items match their index.
                                                    # Since zero was added to the list, there will always be one extra match (0==0). So offset by one.
                                                    sum(........................................................................)-1
                                                    from itertools import*





                                                    share|improve this answer















                                                    Python 2, 125 115 111 bytes





                                                    lambda c:sum(i==j for i,j in enumerate(sorted(set(map(sum,product([0]+c,repeat=8))))))-1
                                                    from itertools import*


                                                    Try it online!



                                                    Expects a list of integers as input.



                                                    Explanation:



                                                    # an anonymous function
                                                    lambda c:
                                                    # get all length-8 combinations of values, from (0,0,0,0,0,0,0,0) to (8,8,8,8,8,8,8,8)
                                                    # zero is added to ensure that combinations of fewer than 8 coins are represented Ex:(1,0,0,0,0,0,0,0)
                                                    product([0]+c,repeat=8)
                                                    # for each combination, sum the values
                                                    map(sum,.......................)
                                                    # get unique values, then sort them smallest to largest
                                                    sorted(set(................................))
                                                    # for each index, value pair, return if the index is equal to the value
                                                    i==j for i,j in enumerate(.............................................)
                                                    # in Python arithmetic, False is 0 and True is 1. So, count how many items match their index.
                                                    # Since zero was added to the list, there will always be one extra match (0==0). So offset by one.
                                                    sum(........................................................................)-1
                                                    from itertools import*






                                                    share|improve this answer














                                                    share|improve this answer



                                                    share|improve this answer








                                                    edited Dec 27 '18 at 16:02

























                                                    answered Dec 26 '18 at 17:33









                                                    Triggernometry

                                                    57517




                                                    57517























                                                        2














                                                        Perl6, 65 63 41 bytes (39 chars)





                                                        {@_=(0,|@_)X+(0,|@_)for ^3;($_ if $_==$++for @_.sort.unique)-1}


                                                        Try it online!



                                                        This is an anonymous block that gets passed its data as an array. The (0,|@_) is a quick way to add a 0 to @_, and even though it's done twice, it's still a bit shorter than @_.push: 0; which would then need spaces after the _. This is a brute force approach that cheeses a bit on the fact that it's 8 combinations. After cross adding, an anonymous list is created for sequential values. With math operators, lists evaluate to their length, so the -1 pulls double duty: accounting for the 0 and coercing to Int.



                                                        This can take its sweet time, but by changing one or both (0,|@_) to (0,|@_.unique) before the first for it can be sped up considerably. That adds +7 (runtime <60s) or +14 (runtime <10s) to the score if you feel the first is too slow (I did this for the linked code to avoid timeouts after 60 seconds).



                                                        Edit: JoKing in the comments improved it (same idea, cross add, then return the last consecutive result) to an astonishing 39 chars (41 bytes):





                                                        {(@_=@_ X+0,|@_)xx 1;first *+1∉@_,0..*}


                                                        Try it online!



                                                        The final tabulation doesn't need a 0, saving a few bytes by only needing to add 0 in once. The xx 3 mimics the for loop (still cheeses on the coins being a power of 2). The first sub returns the first number in the infinite list 0..* (^Inf is possible too, but doesn't save space) whose +1 is not a member of the cross added list. Like mine, it's slow, so add +7 for a unique after the first equals if you feel it's too slow for guidelines.






                                                        share|improve this answer



















                                                        • 1




                                                          48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                          – Jo King
                                                          Dec 28 '18 at 7:14










                                                        • @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                          – guifa
                                                          Dec 28 '18 at 15:17
















                                                        2














                                                        Perl6, 65 63 41 bytes (39 chars)





                                                        {@_=(0,|@_)X+(0,|@_)for ^3;($_ if $_==$++for @_.sort.unique)-1}


                                                        Try it online!



                                                        This is an anonymous block that gets passed its data as an array. The (0,|@_) is a quick way to add a 0 to @_, and even though it's done twice, it's still a bit shorter than @_.push: 0; which would then need spaces after the _. This is a brute force approach that cheeses a bit on the fact that it's 8 combinations. After cross adding, an anonymous list is created for sequential values. With math operators, lists evaluate to their length, so the -1 pulls double duty: accounting for the 0 and coercing to Int.



                                                        This can take its sweet time, but by changing one or both (0,|@_) to (0,|@_.unique) before the first for it can be sped up considerably. That adds +7 (runtime <60s) or +14 (runtime <10s) to the score if you feel the first is too slow (I did this for the linked code to avoid timeouts after 60 seconds).



                                                        Edit: JoKing in the comments improved it (same idea, cross add, then return the last consecutive result) to an astonishing 39 chars (41 bytes):





                                                        {(@_=@_ X+0,|@_)xx 1;first *+1∉@_,0..*}


                                                        Try it online!



                                                        The final tabulation doesn't need a 0, saving a few bytes by only needing to add 0 in once. The xx 3 mimics the for loop (still cheeses on the coins being a power of 2). The first sub returns the first number in the infinite list 0..* (^Inf is possible too, but doesn't save space) whose +1 is not a member of the cross added list. Like mine, it's slow, so add +7 for a unique after the first equals if you feel it's too slow for guidelines.






                                                        share|improve this answer



















                                                        • 1




                                                          48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                          – Jo King
                                                          Dec 28 '18 at 7:14










                                                        • @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                          – guifa
                                                          Dec 28 '18 at 15:17














                                                        2












                                                        2








                                                        2






                                                        Perl6, 65 63 41 bytes (39 chars)





                                                        {@_=(0,|@_)X+(0,|@_)for ^3;($_ if $_==$++for @_.sort.unique)-1}


                                                        Try it online!



                                                        This is an anonymous block that gets passed its data as an array. The (0,|@_) is a quick way to add a 0 to @_, and even though it's done twice, it's still a bit shorter than @_.push: 0; which would then need spaces after the _. This is a brute force approach that cheeses a bit on the fact that it's 8 combinations. After cross adding, an anonymous list is created for sequential values. With math operators, lists evaluate to their length, so the -1 pulls double duty: accounting for the 0 and coercing to Int.



                                                        This can take its sweet time, but by changing one or both (0,|@_) to (0,|@_.unique) before the first for it can be sped up considerably. That adds +7 (runtime <60s) or +14 (runtime <10s) to the score if you feel the first is too slow (I did this for the linked code to avoid timeouts after 60 seconds).



                                                        Edit: JoKing in the comments improved it (same idea, cross add, then return the last consecutive result) to an astonishing 39 chars (41 bytes):





                                                        {(@_=@_ X+0,|@_)xx 1;first *+1∉@_,0..*}


                                                        Try it online!



                                                        The final tabulation doesn't need a 0, saving a few bytes by only needing to add 0 in once. The xx 3 mimics the for loop (still cheeses on the coins being a power of 2). The first sub returns the first number in the infinite list 0..* (^Inf is possible too, but doesn't save space) whose +1 is not a member of the cross added list. Like mine, it's slow, so add +7 for a unique after the first equals if you feel it's too slow for guidelines.






                                                        share|improve this answer














                                                        Perl6, 65 63 41 bytes (39 chars)





                                                        {@_=(0,|@_)X+(0,|@_)for ^3;($_ if $_==$++for @_.sort.unique)-1}


                                                        Try it online!



                                                        This is an anonymous block that gets passed its data as an array. The (0,|@_) is a quick way to add a 0 to @_, and even though it's done twice, it's still a bit shorter than @_.push: 0; which would then need spaces after the _. This is a brute force approach that cheeses a bit on the fact that it's 8 combinations. After cross adding, an anonymous list is created for sequential values. With math operators, lists evaluate to their length, so the -1 pulls double duty: accounting for the 0 and coercing to Int.



                                                        This can take its sweet time, but by changing one or both (0,|@_) to (0,|@_.unique) before the first for it can be sped up considerably. That adds +7 (runtime <60s) or +14 (runtime <10s) to the score if you feel the first is too slow (I did this for the linked code to avoid timeouts after 60 seconds).



                                                        Edit: JoKing in the comments improved it (same idea, cross add, then return the last consecutive result) to an astonishing 39 chars (41 bytes):





                                                        {(@_=@_ X+0,|@_)xx 1;first *+1∉@_,0..*}


                                                        Try it online!



                                                        The final tabulation doesn't need a 0, saving a few bytes by only needing to add 0 in once. The xx 3 mimics the for loop (still cheeses on the coins being a power of 2). The first sub returns the first number in the infinite list 0..* (^Inf is possible too, but doesn't save space) whose +1 is not a member of the cross added list. Like mine, it's slow, so add +7 for a unique after the first equals if you feel it's too slow for guidelines.







                                                        share|improve this answer














                                                        share|improve this answer



                                                        share|improve this answer








                                                        edited Dec 28 '18 at 15:39

























                                                        answered Dec 28 '18 at 5:01









                                                        guifa

                                                        23115




                                                        23115








                                                        • 1




                                                          48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                          – Jo King
                                                          Dec 28 '18 at 7:14










                                                        • @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                          – guifa
                                                          Dec 28 '18 at 15:17














                                                        • 1




                                                          48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                          – Jo King
                                                          Dec 28 '18 at 7:14










                                                        • @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                          – guifa
                                                          Dec 28 '18 at 15:17








                                                        1




                                                        1




                                                        48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                        – Jo King
                                                        Dec 28 '18 at 7:14




                                                        48 bytes. Technically, the unique is not needed, but it speeds it up a lot
                                                        – Jo King
                                                        Dec 28 '18 at 7:14












                                                        @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                        – guifa
                                                        Dec 28 '18 at 15:17




                                                        @JoKing nice, I don't know why I didn't think about using xx. I knew there had to be a way to do the final tabulation in a much shorter way using set functions, but my brain wasn't working.
                                                        – guifa
                                                        Dec 28 '18 at 15:17











                                                        1















                                                        JavaScript (Node.js), 171 145 115 bytes





                                                        f=(s,n=3)=>n?f(s=new Set(a=[0,...s]),n-1,a.map(m=>a.map(n=>s.add(m+n)))):Math.min(...[...s].filter(m=>!s.has(m+1)))


                                                        Try it online! Port of @Mark's Python 3 answer. 108 bytes in Firefox 30-57:



                                                        f=(s,n=3)=>n?f(new Set((for(n of s=[0,...s])for(m of s)n+m)),n-1):Math.min(...[...s].filter(m=>!s.has(m+1)))





                                                        share|improve this answer




























                                                          1















                                                          JavaScript (Node.js), 171 145 115 bytes





                                                          f=(s,n=3)=>n?f(s=new Set(a=[0,...s]),n-1,a.map(m=>a.map(n=>s.add(m+n)))):Math.min(...[...s].filter(m=>!s.has(m+1)))


                                                          Try it online! Port of @Mark's Python 3 answer. 108 bytes in Firefox 30-57:



                                                          f=(s,n=3)=>n?f(new Set((for(n of s=[0,...s])for(m of s)n+m)),n-1):Math.min(...[...s].filter(m=>!s.has(m+1)))





                                                          share|improve this answer


























                                                            1












                                                            1








                                                            1







                                                            JavaScript (Node.js), 171 145 115 bytes





                                                            f=(s,n=3)=>n?f(s=new Set(a=[0,...s]),n-1,a.map(m=>a.map(n=>s.add(m+n)))):Math.min(...[...s].filter(m=>!s.has(m+1)))


                                                            Try it online! Port of @Mark's Python 3 answer. 108 bytes in Firefox 30-57:



                                                            f=(s,n=3)=>n?f(new Set((for(n of s=[0,...s])for(m of s)n+m)),n-1):Math.min(...[...s].filter(m=>!s.has(m+1)))





                                                            share|improve this answer















                                                            JavaScript (Node.js), 171 145 115 bytes





                                                            f=(s,n=3)=>n?f(s=new Set(a=[0,...s]),n-1,a.map(m=>a.map(n=>s.add(m+n)))):Math.min(...[...s].filter(m=>!s.has(m+1)))


                                                            Try it online! Port of @Mark's Python 3 answer. 108 bytes in Firefox 30-57:



                                                            f=(s,n=3)=>n?f(new Set((for(n of s=[0,...s])for(m of s)n+m)),n-1):Math.min(...[...s].filter(m=>!s.has(m+1)))






                                                            share|improve this answer














                                                            share|improve this answer



                                                            share|improve this answer








                                                            edited Dec 27 '18 at 1:29

























                                                            answered Dec 25 '18 at 15:04









                                                            Neil

                                                            79.5k744177




                                                            79.5k744177























                                                                0















                                                                Clean, 161 bytes



                                                                import StdEnv,Data.List
                                                                $l=:[1:_]#k=sort(nub(map sum(iter 8(concatMap([h:t]=[[e,h:t]\e<-[0:l]|e>=h]))[[0]])))
                                                                =length(takeWhile((>=)1)(zipWith(-)(tl k)k))
                                                                $_=0


                                                                Try it online!






                                                                share|improve this answer


























                                                                  0















                                                                  Clean, 161 bytes



                                                                  import StdEnv,Data.List
                                                                  $l=:[1:_]#k=sort(nub(map sum(iter 8(concatMap([h:t]=[[e,h:t]\e<-[0:l]|e>=h]))[[0]])))
                                                                  =length(takeWhile((>=)1)(zipWith(-)(tl k)k))
                                                                  $_=0


                                                                  Try it online!






                                                                  share|improve this answer
























                                                                    0












                                                                    0








                                                                    0







                                                                    Clean, 161 bytes



                                                                    import StdEnv,Data.List
                                                                    $l=:[1:_]#k=sort(nub(map sum(iter 8(concatMap([h:t]=[[e,h:t]\e<-[0:l]|e>=h]))[[0]])))
                                                                    =length(takeWhile((>=)1)(zipWith(-)(tl k)k))
                                                                    $_=0


                                                                    Try it online!






                                                                    share|improve this answer













                                                                    Clean, 161 bytes



                                                                    import StdEnv,Data.List
                                                                    $l=:[1:_]#k=sort(nub(map sum(iter 8(concatMap([h:t]=[[e,h:t]\e<-[0:l]|e>=h]))[[0]])))
                                                                    =length(takeWhile((>=)1)(zipWith(-)(tl k)k))
                                                                    $_=0


                                                                    Try it online!







                                                                    share|improve this answer












                                                                    share|improve this answer



                                                                    share|improve this answer










                                                                    answered Dec 28 '18 at 7:05









                                                                    Οurous

                                                                    6,48211033




                                                                    6,48211033






























                                                                        draft saved

                                                                        draft discarded




















































                                                                        If this is an answer to a challenge…




                                                                        • …Be sure to follow the challenge specification. However, please refrain from exploiting obvious loopholes. Answers abusing any of the standard loopholes are considered invalid. If you think a specification is unclear or underspecified, comment on the question instead.


                                                                        • …Try to optimize your score. For instance, answers to code-golf challenges should attempt to be as short as possible. You can always include a readable version of the code in addition to the competitive one.
                                                                          Explanations of your answer make it more interesting to read and are very much encouraged.


                                                                        • …Include a short header which indicates the language(s) of your code and its score, as defined by the challenge.



                                                                        More generally…




                                                                        • …Please make sure to answer the question and provide sufficient detail.


                                                                        • …Avoid asking for help, clarification or responding to other answers (use comments instead).






                                                                        Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                                                                        Please pay close attention to the following guidance:


                                                                        • Please be sure to answer the question. Provide details and share your research!

                                                                        But avoid



                                                                        • Asking for help, clarification, or responding to other answers.

                                                                        • Making statements based on opinion; back them up with references or personal experience.


                                                                        To learn more, see our tips on writing great answers.




                                                                        draft saved


                                                                        draft discarded














                                                                        StackExchange.ready(
                                                                        function () {
                                                                        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodegolf.stackexchange.com%2fquestions%2f178015%2feight-coins-for-the-fair-king%23new-answer', 'question_page');
                                                                        }
                                                                        );

                                                                        Post as a guest















                                                                        Required, but never shown





















































                                                                        Required, but never shown














                                                                        Required, but never shown












                                                                        Required, but never shown







                                                                        Required, but never shown

































                                                                        Required, but never shown














                                                                        Required, but never shown












                                                                        Required, but never shown







                                                                        Required, but never shown







                                                                        Popular posts from this blog

                                                                        How to change which sound is reproduced for terminal bell?

                                                                        Title Spacing in Bjornstrup Chapter, Removing Chapter Number From Contents

                                                                        Can I use Tabulator js library in my java Spring + Thymeleaf project?