Ranger des boites
Publié le 9 février 2015 par Benoît sous licence CC BY-SA 4.0.
Bonjour à toutes et à tous !
Aujourd'hui nous faisons du rangement, donc pour cela nous avons des cartons en 3D (hauteur, largeur, profondeur) et plein de petites boites à faire rentrer dans la grande boite !
Le but est simple : mettre le plus de boites dans le grand carton, on veut juste le plus de boites possible et non optimiser la place.
Entrée
D'abord, on vous donne les dimensions d'une boite (x, y et z) et toutes les dimensions de chaque petites boites qu'on possède.
Par exemple, on a une boite de 3x3x3 et plein de petites boites :
3 3 3
2 2 2
2 2 2
4 4 4
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
Y a même une boite plus grande que le carton mais le marketing veut vraiment qu'on essaye de la faire rentrer. '-'
Sortie
On peut mettre 8 boites dans la boite de 3x3x3 :
2 2 2
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
Voilà, le code a faire fonctionner :
10 10 10
4 4 4
5 5 1
4 5 1
7 7 7
5 5 5
3 3 3
5 5 5
9 8 7
4 5 1
5 5 1
4 4 4
3 3 3
4 4 4
(pour Guillaume va falloir tout afficher avec des jolies animations, bien sûr ! :p)
Bonne chance !
Travaux réalisés
- Moi-même : Haskell
Mon code
(non finalisé)
data Box = Box {
x :: Int,
y :: Int,
z :: Int
} deriving (Show, Ord, Eq)
type ListBoxes = [Box]
-- inputBoxes :: ListBoxes
inputBoxes = [
Box 3 3 3,
Box 2 2 2,
Box 2 2 2,
Box 4 4 4,
Box 1 1 1,
Box 1 1 1,
Box 1 1 1,
Box 1 1 1,
Box 1 1 1,
Box 1 1 1,
Box 1 1 1]
-- sizeBox :: Box -> Int
sizeBox b = x b * y b * z b
sizeBoxes [] = 1
sizeBoxes (box:xs) =
x box * y box * z box + sizeBoxes xs
-- splitBoxes :: ListBoxes -> (Box, ListBoxes)
splitBoxes (bigBox:boxes) = (bigBox, boxes)
-- bigBox :: Box
-- boxes :: ListBoxes
(bigBox, boxes) = splitBoxes inputBoxes
combinations :: Int -> [a] -> [[a]]
combinations k xs = combinations' (length xs) k xs
where combinations' n k' l@(y:ys)
| k' == 0 = [[]]
| k' >= n = [l]
| null l = []
| otherwise = map (y :) (combinations' (n - 1) (k' - 1) ys) ++ combinations' (n - 1) k' ys
combinationsRecursive' :: ListBoxes -> Int -> [ListBoxes]
combinationsRecursive' boxes 0 = []
combinationsRecursive' boxes len =
combinations len boxes ++ combinationsRecursive' boxes (len - 1)
combinationsRecursive :: ListBoxes -> [ListBoxes]
combinationsRecursive boxes =
combinationsRecursive' boxes (length boxes)
a = combinationsRecursive boxes
-- sizes' [] accum = accum
-- sizes' (listBoxes:xs) accum = sizes' xs $ accum ++ [sizeBoxes listBoxes]
sizes boxes = sizes' boxes []
printSizes [] = do print "end"
printSizes (size:xs) = do
print size
printSizes xs
maxSizes' [] accum = accum
maxSizes' (size:xs) accum =
if size <= sizeBox bigBox then
maxSizes' xs (accum ++ [size])
else
maxSizes' xs accum
maxSizes sizes = maxSizes' sizes []
sizesa = sizes a
-- main :: IO ()
main = do
-- print $ sizeBox bigBox
-- print $ sizeBoxes boxes
print $ maximum $ maxSizes sizesa
-- getLine