89. K数之和

89. K数之和

 

 

给定  n  个不同的正整数,整数  k k  <=  n )以及一个目标数字  target 。 
在这  n  个数里面找出  k  个数,使得这  k  个数的和等于目标数字,求问有多少种方案?

样例

样例1
输入:
List = [1,2,3,4]
k = 2
target = 5
输出: 2
说明: 1 + 4 = 2 + 3 = 5
样例2
输入:
List = [1,2,3,4,5]
k = 3
target = 6
输出: 1
说明: 只有这一种方案。 1 + 2 + 3 = 6
 

public class Solution {
    /**
     * @param A: An integer array
     * @param k: A positive integer (k <= length(A))
     * @param target: An integer
     * @return: An integer
     */
    public int kSum(int[] A, int k, int target) {
         int n = A.length;
        if (n == 0) return 0;
        
            int[][][] f = new int[n + 1][k + 1][target + 1];
            f[0][0][0] = 1;
            for (int i = 1; i <= n; i++) {
                for (int j = 0; j <= k; j++) {
                    for (int t = 0; t <= target; t++) {
//                        if (i == 0)
//                            f[0][j][t] = 0;
//                        else {
                        f[i][j][t] = f[i - 1][j][t];
                        if (t - A[i - 1] >= 0 && j > 0)
                            f[i][j][t] += f[i - 1][j - 1][t - A[i - 1]];
//                        }
                    }
                }
            }


            return f[n][k][target];
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1.% 初始化PN序列   2.PN = [1 0 0 0 0 0 0 0 0 0];   3.   4.% 生成PN序列   5.for i = 1:5   6.    % 计算PN序列的下一个元素   7.    next = mod(PN(10) + PN(3), 2);   8.    % 将PN序列右移一位,并在最左侧插入下一个元素   9.    PN = [next PN(1:9)];   10.end   11.   12.% 打印PN序列   13.disp('PN序列:')   14.disp(PN)   15.   16.% 绘制PN序列的自相关函数   17.autocorr = zeros(1, 19);   18.for k = -9:9   19.    for i = 1:(10 - abs(k))   20.        autocorr(k + 10) = autocorr(k + 10) + PN(i) * PN(i + abs(k));   21.    end   22.end   23.disp('PN序列的自相关函数:')   24.disp(autocorr)   25.figure(1)   26.stem(-9:9, autocorr)   27.title('PN序列的自相关函数')   28.   29.% 只显示前101个元素的部分自相关函数   30.part_autocorr = zeros(1, 101);   31.for k = 1:101   32.    for i = 1:(10 - k)   33.        part_autocorr(k) = part_autocorr(k) + PN(i) * PN(i + k);   34.    end   35.end   36.disp('只显示前101个元素的部分自相关函数:')   37.disp(part_autocorr)   38.figure(2)   39.stem(1:101, part_autocorr)   40.title('只显示前101个元素的部分自相关函数')   41.   42.% 输出PN序列的前101个采样   43.output = [];   44.for i = 1:101   45.    output = [output PN(mod(i - 1, 10) + 1)];   46.end   47.disp('PN序列发生器输出端的前101个采样:')   48.disp(output)   49.figure(3)   50.stem(1:101, output)   51.title('PN序列发生器输出端的前101个采样')  
最新发布
05-22

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时代我西

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值