Sha256: b903a4a414aa435ef769b551588c25b9c8082d4584b56d91b96fa74f63a45e40

Contents?: true

Size: 1.71 KB

Versions: 77

Compression:

Stored size: 1.71 KB

Contents

To try and encourage more sales of different books from a popular 5 book
series, a bookshop has decided to offer discounts on multiple book purchases.

One copy of any of the five books costs $8. 

If, however, you buy two different books, you get a 5%
discount on those two books.

If you buy 3 different books, you get a 10% discount. 

If you buy 4 different books, you get a 20% discount.

If you buy all 5, you get a 25% discount. 

Note: that if you buy four books, of which 3 are
different titles, you get a 10% discount on the 3 that
form part of a set, but the fourth book still costs $8. 

Your mission is to write a piece of code to calculate the
price of any conceivable shopping basket (containing only
books of the same series), giving as big a discount as
possible.

For example, how much does this basket of books cost?

- 2 copies of the first book
- 2 copies of the second book
- 2 copies of the third book
- 1 copy of the fourth book
- 1 copy of the fifth book
 
One way of grouping these 8 books is:

- 1 group of 5 --> 25% discount (1st,2nd,3rd,4th,5th)
- +1 group of 3 --> 10% discount (1st,2nd,3rd)

This would give a total of:

- 5 books at a 25% discount
- +3 books at a 10% discount

Resulting in:

- 5 x (8 - 2.00) == 5 x 6.00 == $30.00
- +3 x (8 - 0.80) == 3 x 7.20 == $21.60

For a total of $51.60

However, a different way to group these 8 books is:

- 1 group of 4 books --> 20% discount  (1st,2nd,3rd,4th)
- +1 group of 4 books --> 20% discount  (1st,2nd,3rd,5th)

This would give a total of:

- 4 books at a 20% discount
- +4 books at a 20% discount

Resulting in:

- 4 x (8 - 1.60) == 4 x 6.40 == $25.60
- +4 x (8 - 1.60) == 4 x 6.40 == $25.60

For a total of $51.20

And $51.20 is the price with the biggest discount.

Version data entries

77 entries across 77 versions & 1 rubygems

Version Path
trackler-2.2.1.39 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.38 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.37 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.36 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.35 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.34 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.33 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.32 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.31 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.30 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.29 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.28 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.27 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.26 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.25 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.24 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.23 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.22 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.21 problem-specifications/exercises/book-store/description.md
trackler-2.2.1.20 problem-specifications/exercises/book-store/description.md