Saturday, 7 February 2015

Shop selling problem

Question:
Mr. Xhas recently shut down his factory and wants to sell off his metal rods to a local businessman. Mr. Octopus has many rods whose length are represented by array - lengths = {lengths[0], lengths[1], lengths[2],...}.The local businessman will only pay for rods that have same length. Let's say Mr. Octopus plans to sell rods of lengthL only. Then he had to cut each rod 0 or more time, so that he can maximize the profit. The remaining rods whose length is not L will be thrown away. Price of N rods of length L will be N × L × unit_price. Also note that for each cut made to a rod, he had to pay cut_cost.

What is the maximum amount of money Mr. Octopus can make? You have to complete the function int maxProfit(int cut_cost, int unit_price, int[] lengths).

My Solution Stratagy:

The problem states we have to find solution in such a way that seller must get maximum profit.you can do this by cutting irons with minimum length(I assume that if we take a minimum length iron ,we can cut  lot number of pieces ,so that seller profit become high)

pseudo code :

1.get the minimum length iron from given array of items

2.cut each and every iron with respect to minimum length iron

3.thrown away if some of irons length not compatable with minimum iron.


Program Solution:

ShopSelling.java
/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package craeercu.com;

/**
 *
 * @author shashi
 */
public class ShopSelling {
   
    //the person gives iron ores ,cuting cost,unit cost return total cosst
    public int totalcost(int unitcost,int cuttngcost,int[]irons)
    {
       
        //to get max profit select a minimum length iron from given itorns
        //get the min length iron
        int shortiron=miniron(irons);
        //get each and every irin from the array of irons and match with shortiron
        //if it is equal  or atleast great
        int numberofirons=0;
        int noofcuttings=0;
        int currentiron;
        int aftercutting;
        for(int i=0;i<irons.length;i++)
        {
            //get the first one
           currentiron=irons[i];
           //check for x length ie short
           if(currentiron>shortiron)
           {
               //cut this till you find some exact length
               while(currentiron>=shortiron)
               {
                   aftercutting=currentiron-shortiron;
                   noofcuttings++;
                   numberofirons++;
                   currentiron=aftercutting;
               }
           }
           if(currentiron==shortiron)
           {
               //for same length irons
          
               numberofirons++;
           }
          
           
        }
        //calclate final result
        int result=(numberofirons*unitcost*shortiron)-(noofcuttings*cuttngcost);
        return result;
    }
    public int miniron(int []irons)
    {
        int min=irons[0];
        for(int i=1;i<irons.length;i++)
        {
            if(irons[i]<min)
                min=irons[i];
        }
        return min;
    }
 
   
}

MainClass

/**
 *
 * @author shashi
 */
public class CraeercuCom {

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        // TODO code application logic here
        ShopSelling sell=new ShopSelling();
        int []irons={10,20,30,40};
        int cost=sell.totalcost(10, 1, irons);
        System.out.print(cost);
    }
   
}




No comments: