Solved

File Backup

Posted on 1997-03-17
1
142 Views
Last Modified: 2010-04-04
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.
0
Comment
Question by:ericw
1 Comment
 
LVL 3

Accepted Solution

by:
sperling earned 100 total points
ID: 1334771
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
repeat
  Increase floppy count
  FloppyUsed := 0
  repeat
    if Size of file (FileToTest) <= Available on current floppy
      Increase FloppyUsed with size of file FileToTest
      Remove file FileToTest from filelist
    else
      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.


Regards,

Erik.
0

Featured Post

Highfive Gives IT Their Time Back

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

Suggested Solutions

Title # Comments Views Activity
Mydac connection data base issue 3 107
Machine not responding during CopyFile() 3 79
Delphi selector screen 2 58
LAN or WAN ? 11 66
The uses clause is one of those things that just tends to grow and grow. Most of the time this is in the main form, as it's from this form that all others are called. If you have a big application (including many forms), the uses clause in the in…
In my programming career I have only very rarely run into situations where operator overloading would be of any use in my work.  Normally those situations involved math with either overly large numbers (hundreds of thousands of digits or accuracy re…
This video discusses moving either the default database or any database to a new volume.
This demo shows you how to set up the containerized NetScaler CPX with NetScaler Management and Analytics System in a non-routable Mesos/Marathon environment for use with Micro-Services applications.

746 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now