Fractional knapsack problem in c++(greedy algorithm):
/* The Knapsack problem */
#include <iostream>
using namespace std;
int max(int a, int b)
{ return (a > b)? a : b; }
int kSack(int W, int wt[], int val[], int n)
{
if (n == 0 || W == 0)
return 0;
if (wt[n-1] > W)
return kSack(W, wt, val, n-1);
else return max( val[n-1] + kSack(W-wt[n-1], wt, val, n-1),
kSack(W, wt, val, n-1) );
}
int main()
{
int val[] = {60, 100, 120};
int wt[] = {10, 20, 30};
int W = 40;
int n = sizeof(val)/sizeof(val[0]);
cout<<kSack(W, wt, val, n);
return 0;
}
0 Comments
Post a Comment
thnaks for you comment...