数字组合 (计蒜客 - T1218)

简介: 数字组合 (计蒜客 - T1218)

题目:

.小蒜有 n(1≤n≤20)n(1 \le n \le 20)n(1≤n≤20) 个正整数,找出其中和为 t(tt(tt(t 也是正整数)的可能的组合方式。如:

n=5,5n=5,5n=5,5 个数分别为 1,2,3,4,51,2,3,4,51,2,3,4,5,t=5t=5t=5;

那么可能的组合有 5=1+45=1+45=1+4 和 5=2+35=2+35=2+3 和 5=55=55=5 三种组合方式。

输入格式

输入的第一行是两个正整数 nnn 和 ttt,用空格隔开,其中 1≤n≤201 \le n \le 201≤n≤20, 表示正整数的个数,ttt 为要

求的和 (1≤t≤1000)(1 \le t \le 1000)(1≤t≤1000)

接下来的一行是 nnn 个正整数,用空格隔开。

输出格式

和为 ttt 的不同的组合方式的数目。

输出时每行末尾的多余空格,不影响答案正确性

样例输入
5 5
1 2 3 4 5
样例输出
3

解题思路:这个题就是动态规划,输入n个数,看看能有多少种方式让这n个数组合成和为t。也就是要求dp[t]的种数可以先求dp[ t-a[i] ]…

程序代码:

#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int main()
{
  int a[1000],f[10010];
  int i,j,t,m,n;
  while(scanf("%d%d",&n,&t)!=EOF)
  {
    memset(f,0,sizeof(f));
    f[0]=1;//f[0]只有0一种方式
    for(i=1;i<=n;i++)
      scanf("%d",&a[i]);
    for(i=1;i<=n;i++)
      for(j=t;j>=a[i];j--)
        f[j]+=f[j-a[i]];
    printf("%d\n",f[t]);  
  }
  return 0;
}
相关文章
给定一个正整数N,将其表示为数字1,3,7,15相加的形式输出。请编码找出使上述数字出现的总次数最少(每个数字可以重复使用)的组合。
给定一个正整数N,将其表示为数字1,3,7,15相加的形式输出。请编码找出使上述数字出现的总次数最少(每个数字可以重复使用)的组合。
|
19天前
|
算法 测试技术 C#
【多数组合 数学 字符串】2514. 统计同位异构字符串数目
【多数组合 数学 字符串】2514. 统计同位异构字符串数目
|
6月前
|
算法 测试技术 C#
C++二分查找算法:最大为 N 的数字组合
C++二分查找算法:最大为 N 的数字组合
|
10月前
数字的转化规则?
转换规则:不管你要转的数据是什么,都是一位一位的去检测,如果第一位可以转成数字,就转,依次往后看每一位,直到碰到不能转或者转完为止,如果转不成就直接NaN
|
11月前
1291:数字组合
1291:数字组合
|
算法
如何在不把数字转为字符串的前提下反转数字
算法问题:如何在不把数字转为字符串的前提下反转数字
53 0
|
Python
【python实战】top1 数字组合——有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
【python实战】top1 数字组合——有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
491 0
【python实战】top1 数字组合——有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
Day27——39. 组合总和 40.组合总和II 131.分割回文串
Day27——39. 组合总和 40.组合总和II 131.分割回文串
76 0
|
算法 JavaScript API
你有几种方式实现数字千分位分割?
前言 这既是一道常见的面试题,也是实际工作中常见的一个需求。这虽然不是一道算法题,但是它是一道发散性思维的题目,想要实现这个功能有很多种方法,这就要看你能够想出几种方法了,本篇文章只列出常见的几种,就相当于抛砖引玉了。
296 0