动态规划算法 

package algorithm;

public class T7_21 {
    public static void main(String[] args){
        int s[] = {2,3,5,6};
        int v[] = {3,4,5,7};
        int C =11;
        
        System.out.println(big(s,v,C));
    }
    
    public static int big(int[] s,int [] v,int C){
        int L_s = s.length;
        int V[][] = new int[100][100];
        for(int i =0;i<=L_s;i++){
            V[i][0] = 0;
        }
        for(int j =0;j<=C;j++){
            V[0][j] = 0;
        }
        for(int i =1;i<=L_s;i++){
            for(int j =1;j<=C;j++){
                V[i][j] = V[i-1][j];
                if(s[i-1]<=j){
                    V[i][j] = V[i][j]>(V[i-1][j-s[i-1]]+v[i-1])?V[i][j]:(V[i-1][j-s[i-1]]+v[i-1]);
                }
            }
        }
        for(int i =0;i<=L_s;i++){
            for(int j = 0;j<=C;j++){
            System.out.printf("%3d",V[i][j]);}
            System.out.println();
        }
        System.out.print("          背包的最大价值为:");
        return V[L_s][C];
    }

}

 

相关文章:

  • 2021-12-11
  • 2021-09-01
  • 2021-11-03
  • 2021-04-01
  • 2021-06-06
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-07-09
  • 2022-12-23
  • 2022-12-23
  • 2021-05-22
  • 2021-05-27
  • 2021-10-29
相关资源
相似解决方案