Advertisement
apl-mhd

coin Change minimum supply 1D array

Mar 27th, 2018
171
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.09 KB | None | 0 0
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <climits>
  4. #include <algorithm>
  5. #include <vector>
  6. #include <stack>
  7. #include <queue>
  8. #include <cmath>
  9. using namespace std;
  10.  
  11.  
  12. int main() {
  13.  
  14.  
  15.     int coins [] = {2,3,4,23};
  16.  
  17.  
  18.     int max =999;
  19.  
  20.  
  21.  
  22.     int M[8];
  23.     M[0]=0;
  24.  
  25.     for(int i=1; i<8; i++)
  26.         M[i] = 9999;
  27.  
  28.     int track[8];
  29.     track[0]=0;
  30.  
  31.  
  32.  
  33.     int sum =0 ;
  34.  
  35.  
  36.     for(int i=0; i<4; i++){
  37.  
  38.         sum+=coins[i];
  39.        
  40.        
  41.  
  42.         for(int j=coins[i]; j<=7; j++){
  43.  
  44.  
  45.  
  46.             if(coins[i]<=sum){
  47.  
  48.                 if(1+M[j-coins[i]]< M[j]){
  49.  
  50.                     M[j] = 1+M[j-coins[i]];
  51.  
  52.  
  53.                     track[j] = coins[i];
  54.                 }
  55.  
  56.                 // M[j] = min(1+M[j-coins[i]],M[j]);
  57.  
  58.             }
  59.  
  60.  
  61.         }
  62.     }
  63.  
  64.  
  65.  
  66.     for(int i=1; i<8; i++)
  67.         cout<<M[i]<<" ";
  68.  
  69.     cout<<endl;
  70.  
  71.     for(int i=0; i<8; i++)
  72.         cout<<i<<" : "<<track[i]<<endl;
  73.  
  74.     cout<<endl;
  75.  
  76.     int end =7;
  77.  
  78.     while(end !=0){
  79.  
  80.         cout<<track[end]<<" ";
  81.  
  82.         end -=track[end];
  83.     }
  84.  
  85.  
  86.     return 0;
  87. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement