解题思路:
注意事项:
参考代码:
Scanner scanner=new Scanner(System.in); int m=scanner.nextInt(); int n=scanner.nextInt(); int [] v=new int [n+1]; int [][] arr=new int [n+1][m+1]; for (int i =1 ; i <=n; i++) { v[i]=scanner.nextInt(); } for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { if (v[i]<=j) { arr[i][j]=Math.max(arr[i-1][j],arr[i-1][j-v[i]]+v[i] ); }else { arr[i][j]=arr[i-1][j]; } } } System.out.println(m-arr[n][m]);
0.0分
2 人评分
C语言训练-字符串正反连接 (C语言代码)浏览:726 |
C语言程序设计教程(第三版)课后习题12.1 (C语言代码)浏览:1026 |
破解简单密码 (C语言代码)浏览:1864 |
printf基础练习2 (C语言代码)浏览:648 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:695 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:770 |
C语言训练-自由落体问题 (C语言代码)浏览:1775 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:940 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:611 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:584 |