Sha256: 4237084418399af39dbe4568c5f3f705529f221b3f45b9d15e47368f2940e4d1

Contents?: true

Size: 1.17 KB

Versions: 86

Compression:

Stored size: 1.17 KB

Contents

package bookstore

import "math"

const bookPrice = 800 // 800 cents = $8.00

var discountTiers = [...]int{0, 5, 10, 20, 25}

// Cost implements the book store exercise.
func Cost(books []int) int {
	return cost(books, 0)
}

func cost(books []int, priceSoFar int) int {
	if len(books) == 0 {
		return priceSoFar
	}

	distinctBooks, remainingBooks := getDistinctBooks(books)
	minPrice := math.MaxInt32

	for i := 1; i <= len(distinctBooks); i++ {
		newRemainingBooks := make([]int, len(remainingBooks))
		copy(newRemainingBooks, remainingBooks)
		newRemainingBooks = append(newRemainingBooks, distinctBooks[i:]...)

		price := cost(newRemainingBooks, priceSoFar+groupCost(i))
		if price < minPrice {
			minPrice = price
		}
	}

	return minPrice
}

func getDistinctBooks(books []int) (distinct []int, remaining []int) {
	exists := make(map[int]bool)
	for _, book := range books {
		if exists[book] {
			remaining = append(remaining, book)
		} else {
			distinct = append(distinct, book)
			exists[book] = true
		}
	}

	return
}

func groupCost(groupSize int) int {
	normalPrice := bookPrice * groupSize
	discount := (normalPrice * discountTiers[groupSize-1]) / 100
	return normalPrice - discount
}

Version data entries

86 entries across 86 versions & 1 rubygems

Version Path
trackler-2.2.1.139 tracks/go/exercises/book-store/example.go
trackler-2.2.1.138 tracks/go/exercises/book-store/example.go
trackler-2.2.1.137 tracks/go/exercises/book-store/example.go
trackler-2.2.1.136 tracks/go/exercises/book-store/example.go
trackler-2.2.1.135 tracks/go/exercises/book-store/example.go
trackler-2.2.1.134 tracks/go/exercises/book-store/example.go
trackler-2.2.1.133 tracks/go/exercises/book-store/example.go
trackler-2.2.1.132 tracks/go/exercises/book-store/example.go
trackler-2.2.1.131 tracks/go/exercises/book-store/example.go
trackler-2.2.1.130 tracks/go/exercises/book-store/example.go
trackler-2.2.1.129 tracks/go/exercises/book-store/example.go
trackler-2.2.1.128 tracks/go/exercises/book-store/example.go
trackler-2.2.1.127 tracks/go/exercises/book-store/example.go
trackler-2.2.1.126 tracks/go/exercises/book-store/example.go
trackler-2.2.1.125 tracks/go/exercises/book-store/example.go
trackler-2.2.1.124 tracks/go/exercises/book-store/example.go
trackler-2.2.1.123 tracks/go/exercises/book-store/example.go
trackler-2.2.1.122 tracks/go/exercises/book-store/example.go
trackler-2.2.1.121 tracks/go/exercises/book-store/example.go
trackler-2.2.1.120 tracks/go/exercises/book-store/example.go