File Backup

How does one go about calculating the minimum number of floppy disks required to backup a given list of files? I believe this is called the 'KnapSack' problem, but I've never managed to find someone who's solved it.
Who is Participating?
sperlingConnect With a Mentor Commented:
Hmmm... I've solved it. And so has others i know... However, a few assumptations must ofcourse be made.

Okie. Assumptations are as follows:
You have a list of files, and ofcourse the sizes in bytes of each file.
You know what kind of floppies will be used, and all floppies are equal.
AND, the floppies ain't formatted in some weird format.
Standard floppy format uses a block size of 512 bytes.

I'll just pretend all files are smaller than the available space on one floppy. If you need to split files, filling up the floppies ain't a problem.

Calculate number of blocks on floppy, by taking size of an empty floppy and divide by 512

Take all the file sizes. If they are not dividable by 512, increase their sizes until they are.

Divide all sizes by 512 and store these values as the file sizes. Sort the filelist based on size, largest files first

Here's some pseudo-code:

FileToTest := First file
FloppyCount := 0
  Increase floppy count
  FloppyUsed := 0
    if Size of file (FileToTest) <= Available on current floppy
      Increase FloppyUsed with size of file FileToTest
      Remove file FileToTest from filelist
      Increase FileToTest
  until (FileToTest = last file) or (Floppy is full) or (No more files)


  FileToTest := first file
  FloppyUsed := 0
until No more files

If last floppy is empty
  Decrease FloppyCount

This code *will* fill up the floppies, although it doesn't necessarily seem so at first glance.


Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.