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

可以轻易推出公式 :(n1+n2+n3+...nn)!/(n1!*n2!*...*nn!);

因为15!还在long long的范围之内,可以先定义一个数组f[15]保存1~15的阶乘,接着就是将(n1+n2+n3+...nn)!计算出来并存到数组内,接着就是大数除法了(相当于一个大数除一个小数)。

  1. #include <iostream>
  2. #include <algorithm>
  3. #include <cstring>
  4. #include <cstdio>
  5. #include <cctype>
  6. #include <cstdlib>
  7. #include <stack>
  8. #include <cmath>
  9. #include <string>
  10. #include <queue>
  11.  
  12. using namespace std;
  13. #define SIZE 30
  14. typedef long long ll ;
  15. int d[SIZE] ;
  16. int ans[] , f[];
  17. void multiply(int c){
  18. ans[] = ans[] = ;
  19. for(int i = ; i <= c ; ++i){
  20. int r = ;
  21. for(int j = ; j <= ans[] ; ++j){
  22. ans[j] *= i ;
  23. ans[j] += r ;
  24. r = ans[j]/ ;
  25. ans[j] %= ;
  26. }
  27. if(r != ){
  28. while(r){
  29. ans[ans[]+] += r% ;
  30. ans[] = ans[]+ ;
  31. r /= ;
  32. }
  33. }
  34. }
  35. }
  36.  
  37. void divide(int n){
  38. for(int i = ; i < n ; ++i){
  39. if(d[i] == ) continue ;
  40. ll r = ;
  41. for(int j = ans[] ; j > ; --j){
  42. r = r* + ans[j] ;
  43. ans[j] = (int)(r/f[d[i]]) ;
  44. r %= f[d[i]] ;
  45. }
  46. int j = ans[] ;
  47. while(!ans[j--]) ;
  48. ans[] = j+ ;
  49. }
  50. }
  51.  
  52. int main(){
  53. int n ;
  54. f[] = f[] = ;
  55. for(int i = ; i < ; ++i)
  56. f[i] = f[i-]*i ;
  57. while(scanf("%d",&n) && n){
  58. int c = ;
  59. memset(ans,,sizeof(ans)) ;
  60. for(int i = ; i < n ; ++i){
  61. scanf("%d",&d[i]) ;
  62. c += d[i] ;
  63. }
  64. multiply(c) ;
  65. divide(n) ;
  66. for(int i = ans[] ; i > ; --i)
  67. printf("%d",ans[i]) ;
  68. puts("") ;
  69. }
  70. return ;
  71. }

2017-3-4再做这道题,用了Java~~哈哈

  1. import java.math.BigInteger;
  2.  
  3. /**
  4. *
  5. * @author Asimple
  6. *
  7. */
  8.  
  9. import java.util.Scanner;
  10. public class Main{
  11. static Scanner sc = new Scanner(System.in);
  12. public static void main(String[] args) {
  13. int n;
  14. while( sc.hasNext() ) {
  15. n = sc.nextInt();
  16. if( n == 0 ) break;
  17. int sum = 0;
  18. BigInteger a = BigInteger.valueOf(1);
  19. for(int i=0; i<n; i++) {
  20. int num = sc.nextInt();
  21. sum += num;
  22. a = a.multiply(dd(num));
  23. }
  24. BigInteger b = dd(sum);
  25. b = b.divide(a);
  26. System.out.println(b.toString());
  27. }
  28. }
  29.  
  30. public static BigInteger dd(int x) {
  31. BigInteger a = BigInteger.valueOf(1) ;
  32. for(int i=2; i<=x; i++) {
  33. a = a.multiply(BigInteger.valueOf(i));
  34. }
  35. return a;
  36. }
  37. }

ACM题目————字串数的更多相关文章

  1. 字串数_hdu_1261(大数极致).java

    字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

  2. HDOJ 1261 字串数

    JAVA大数.... 字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  3. HDU 1261 字串数(排列组合)

    字串数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...

  4. 题解报告:hdu 1261 字串数

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1261 Problem Description 一个A和两个B一共可以组成三种字符串:"ABB ...

  5. hdu 1261 字串数

    解题思路:ACM紫书 第十章 P319 有重复元素的全排列 答案: 所有数的和的阶乘 除以 每个数阶乘的乘积 因为给定 (26*12)! 会爆掉(long long),这里用java 的BigInte ...

  6. 【字符串】BZOJ上面几个AC自动机求最为字串出现次数的题目

    (一下只供自己复习用,目的是对比这几个题,所以写得不详细.需要细节的可以参考其他博主) [BZOJ3172:单词] 题目: 某人读论文,一篇论文是由许多(N)单词组成.但他发现一个单词会在论文中出现很 ...

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

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4333 关于kmp next数组求最短重复字串问题请看:http://www.cnblogs.com/z ...

  8. Day07 - Ruby比一比:Symbol符号与String字串

    前情提要: 第六天我们透过Ruby代码练习public,protected和privatemethod时,发现冒号在前面的参数,:mydraft,:myspace,这些就是符号Symbol.在今天,我 ...

  9. POJ - 2774~POJ - 3415 后缀数组求解公共字串问题

    POJ - 2774: 题意: 求解A,B串的最长公共字串 (摘自罗穗骞的国家集训队论文): 算法分析: 字符串的任何一个子串都是这个字符串的某个后缀的前缀. 求 A 和 B 的最长 公共子串等价于求 ...

随机推荐

  1. my.cnf详解

    [client] port = 3306 socket = /tmp/mysql.sock [mysqld] port = 3306 socket = /tmp/mysql.sock basedir ...

  2. rpmdb出问题,重建rpmdb库

    1.备份原库 tar cvzf rpmdb-backup.tar.gz /var/lib/rpm 2.删除rpmdb库 rm -f /var/lib/rpm/__db.00* 3.重建库 rpm -- ...

  3. C# SQL优化 及 Linq 分页

    每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...

  4. js 点击展开、收起

    //点击展开.收起 window.onload=function(){ var current=document.getElementsByTagName('li')[0]; document.bod ...

  5. Leetcode: Nth Digit

    Find the nth digit of the infinite integer sequence 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ... Note: n i ...

  6. [Reprint] C++函数模板与类模板实例解析

    这篇文章主要介绍了C++函数模板与类模板,需要的朋友可以参考下   本文针对C++函数模板与类模板进行了较为详尽的实例解析,有助于帮助读者加深对C++函数模板与类模板的理解.具体内容如下: 泛型编程( ...

  7. C#: 异步委托

    http://www.cnblogs.com/yingzhongwen/p/4568350.html 讲了委托与事件,但是对异步委托研究得还不够深入. http://www.cnblogs.com/l ...

  8. maven笔记-入门(helloWorld)

    maven: pom.xml:文件 groupId,artifactId,Version定义了一个项目的基本坐标 groupId:定义了项目属于哪个组,往往与项目所在的组织和公司有关 artifact ...

  9. centos dhcp网络设置

    CentOS 网络设置修改   一.CentOS 修改IP地址 修改对应网卡的IP地址的配置文件# vi /etc/sysconfig/network-scripts/ifcfg-eth0 修改以下内 ...

  10. WebForm中<%=%>与<%#%>的区别?

    1<%=%>相当于Response.Write(),是输出变量的值 2<%#%>专门用于数据绑定,可以绑定一些变量或者数据源中的信息,中间绑定是数据源的条目,若想让它起作用,必 ...