HDU 1261 字串数

字串数

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 3187    Accepted Submission(s): 757

Problem Description

一个A和两个B一共可以组成三种字符串:"ABB","BAB","BBA".
给定若干字母和它们相应的个数,计算一共可以组成多少个不同的字符串.

Input

每组测试数据分两行,第一行为n(1<=n<=26),表示不同字母的个数,第二行为n个数A1,A2,...,An(1<=Ai<=12),表示每种字母的个数.测试数据以n=0为结束.

Output

对于每一组测试数据,输出一个m,表示一共有多少种字符串.

Sample Input

2

1 2

3

2 2 2

0

Sample Output

3

90

排列组合题。

答案是 sigma( Ai ) ! / sigama( Ai ! )   全排列除去重复部分 。

答案爆ULL , 写了个JAVA大数

import java.io.*;
import java.math.*;
public class Main {
    public static void main(String args[])throws IOException
    {
        StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));
        BigInteger data[]=new BigInteger[30];
        int [] x = new int[30];
        while(true){

            st.nextToken();
            int n=(int)st.nval;
            if( n == 0 ) break ;
            int sum = 0 ;
            for(int i=1;i<=n;i++)
            {
                st.nextToken();
                x[i]=(int)st.nval;
                sum += x[i];
            }

            BigInteger res=BigInteger.ONE;

            for( int i = 1 ; i <= sum ; ++i ){
                res = res.multiply(BigInteger.valueOf(i));
            }
            for( int i = 1 ; i <= n ; ++i ){
                for( int j = 1 ; j <= x[i] ; ++j ){
                    res = res.divide( BigInteger.valueOf(j) );
                }
            }
            out.println(res);
        }
        out.close();
    }
}

时间: 2024-10-04 11:53:43

HDU 1261 字串数的相关文章

Hdu 1261字串数

字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 4683    Accepted Submission(s): 1234 Problem Description 一个A和两个B一共可以组成三种字符串:"ABB","BAB","BBA".给定若干字母和它们相应的个数,计算一共可以组成

hdu 1261 字串数 排列组合

字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 3505    Accepted Submission(s): 855 Problem Description 一个A和两个B一共可以组成三种字符串:"ABB","BAB","BBA". 给定若干字母和它们相应的个数,计算一共可以组

组合数学 + 大数乘法 + 大数除法 之 hdu 1261 字串数

//  [3/17/2015 JmingS] /* 此题可直接推导出公式: {(A1+A2+……+An)!} / {A1!A2!……An!} 由于 (12×26)! = 312! 只能通过数组来存储,所以又涉及『大数乘法』和『大数除法』, 大数实现的主要思想模拟手算,具体参考程序. */ 1 #include <iostream> 2 #include <cstdlib> 3 #include <cstdio> 4 #include <cstring> 5

HDOJ 1261 字串数

JAVA大数.... 字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 2893    Accepted Submission(s): 679 Problem Description 一个A和两个B一共可以组成三种字符串:"ABB","BAB","BBA". 给定若干字母和它们相应

Problem1261 字串数

字串数 http://acm.hdu.edu.cn/showproblem.php?pid=1261 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 5281    Accepted Submission(s): 1398 Problem Description 一个A和两个B一共可以组成三种字符串:"ABB","BA

字串数 排练组合(阶乘) java秒

字串数 题目抽象:给定若干字母和它们相应的个数,计算一共可以组成多少个不同的字符串. 1 import java.math.*; 2 import java.util.*; 3 import java.io.*; 4 import java.text.*; 5 6 public class Main 7 { 8 9 public static void main(String[] args) 10 { 11 Scanner cin=new Scanner(new BufferedInputStr

[HDOJ1261]字串数

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1261 解题思路很好想,设一共有n=n1+n2+...nk个字符,分别出现n1,n2,...nk次,则组合数有n!/(n1!n2!...nk!)种 难点在大数运算上 1 #include <cstdio> 2 #include <cstdlib> 3 #include <cstring> 4 #include <algorithm> 5 #include <

ACM题目————字串数

Description 一个A和两个B一共可以组成三种字符串:"ABB","BAB","BBA". 给定若干字母和它们相应的个数,计算一共可以组成多少个不同的字符串. Input 每组测试数据分两行,第一行为n(1<=n<=26),表示不同字母的个数,第二行为n个数A1,A2,...,An(1<=Ai<=12),表示每种字母的个数.测试数据以n=0为结束. Output 对于每一组测试数据,输出一个m,表示一共有多少种字符

hdu 4333 扩展kmp+kmp重复字串去重

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4333 关于kmp next数组求最短重复字串问题请看:http://www.cnblogs.com/z1141000271/p/7406198.html 扩展kmp请看:http://www.cnblogs.com/z1141000271/p/7404717.html 题目大意:一个数字,依次将第一位放到最后一位,问小于本身的数的个数及等于本身的个数和大于本身的个数,但是要注意重复的不再计算 题解: