解题思路:
注意事项:
参考代码:
import java.util.Scanner; public class 数字组合 { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Scanner sc=new Scanner(System.in); int n=sc.nextInt(); int t=sc.nextInt(); int[] a=new int[n+1]; for (int i = 1; i <= n; i++) { a[i]=sc.nextInt(); } int[][] dp=new int[n+1][t+1]; dp[0][0]=1; for (int i = 1; i <= n; i++) { for (int j = 0; j <= t; j++) { if (a[i]>j) { dp[i][j]=dp[i-1][j]; }else { dp[i][j]=dp[i - 1][j] + dp[i-1][j - a[i]]; } } } System.out.println(dp[n][t]); } }
0.0分
2 人评分
2004年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:702 |
简单的a+b (C语言代码)浏览:685 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:806 |
C语言训练-计算一个整数N的阶乘 (C语言代码)浏览:986 |
输出正反三角形 (C语言代码)浏览:860 |
母牛的故事 (C语言代码)浏览:992 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:1314 |
【矩阵】 (C++代码)浏览:999 |
1642题解浏览:784 |
输入输出格式练习 (C语言代码)浏览:883 |