题意:

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

思路:

刚开始一看这个题目感觉指数型母函数,结果直接水敲,然后水wa了,哎,SB了,后来大体一算这个题目的答案肯定是几百位,然后就自己写啊写啊写,各种wa,后来放弃了,干脆去学JAVA大数,之前没用过,就输入输出,转换格式,class什么的捅咕了一个晚上,终于a了,费劲啊,

其实这个题目没有必要用母函数,母函数计算什么的复杂(自己JAVA什么不会,刚学的结合到母函数里就感觉复杂了) , 其实我们可以用组合数学的思想来做 ,想想假如有N个不同的数,他们能组合的个数是 N!,但是本题中则可能出现相同的数字,所以答案肯定相对较少,

我们先假设这些数字不同,则是 N!(n 不是题目中的n而是所有数字的总个数 sum),然后考虑出现相同的情况, 假如有AAA,当初我们把他们当成三个不同的数,所以只要除以这三个数的组合数(1 * 2 * 3)就能还原回去了,所有的都这么处理,答案则是:

sum : 所有数字个数和

c[i] : i 有多少个

ans =    sum! / (c[1]! * c[2]! * .....*c[n]!);

下面是自己的 WA的母函数 和 Ac的组合数(Ac的这个代码是在网上找的,自己一开始JAVA什么都不会 ,明天会再写个JAVA 常用的东西)

#include<stdio.h>

double c[30] ,c1[26*12+10] ,c2[26*12+10];
double jcs[15];void DB_JC()
{jcs[0] = 1;for(int i = 1 ;i <= 13 ;i ++)jcs[i] = jcs[i-1] * i;
}int main ()
{int i ,j ,k ,n ,m;while(scanf("%d" ,&n) && n){m = 0;for(i = 1 ;i <= n ;i ++){scanf("%lf" ,&c[i]);m += int(c[i]);}for(i = 0 ;i <= m ;i ++)c1[i] = c2[i] = 0;DB_JC();c1[0] = 1.0 / jcs[0];for(i = 1 ;i <= n ;i ++){for(j = 0 ;j <= m ;j ++)for(k = 0 ;k + j <= m && k <= c[i] ;k ++)c2[k+j] += c1[j]/jcs[k];for(j = 0 ;j <= m ;j ++)c1[j] = c2[j] ,c2[j] = 0;}printf("%I64d\n" ,int(c1[m] * jcs[m]));}return 0;
}

组合数学 Ac JAVA 代码

import java.util.Scanner;
import java.math.BigInteger;public class Main
{public static void main(String args[]) {Scanner cin = new Scanner(System.in);BigInteger f1, f2;int []s = new int[26];int n, sum;n = cin.nextInt();while (n != 0){sum = 0;for (int i=0; i<n; ++i){s[i] = cin.nextInt();sum += s[i];}f1 = new BigInteger("1");for (int i=1; i<=sum; ++i){f1 = f1.multiply(BigInteger.valueOf(i));}f2 = new BigInteger("1");for (int i=0; i<n; ++i){for (int j=1; j<=s[i]; ++j){f2 = f2.multiply(BigInteger.valueOf(j));}}System.out.println(""+f1.divide(f2));n = cin.nextInt();}}
}

hdu1261 JAVA相关推荐

  1. springboot实现SSE服务端主动向客户端推送数据,java服务端向客户端推送数据,kotlin模拟客户端向服务端推送数据

    SSE服务端推送 服务器向浏览器推送信息,除了 WebSocket,还有一种方法:Server-Sent Events(以下简称 SSE).本文介绍它的用法. 在很多业务场景中,会涉及到服务端向客户端 ...

  2. Java 获取当前时间之后的第一个周几,java获取当前日期的下一个周几

    Java 获取当前时间之后的第一个周几,java获取当前日期的下一个周几 //获得入参的日期 Calendar cd = Calendar.getInstance(); cd.setTime(date ...

  3. 在k8s中使用gradle构建java web项目镜像Dockerfile

    在k8s中使用gradle构建java web项目镜像Dockerfile FROM gradle:6-jdk8 AS build COPY --chown=gradle:gradle . /home ...

  4. Java | kotlin 手动注入bean,解决lateinit property loginService has not been initialized异常

    kotlin.UninitializedPropertyAccessException: lateinit property loginService has not been initialized ...

  5. SpringBoot项目使用nacos,kotlin使用nacos,java项目使用nacos,gradle项目使用nacos,maven项目使用nacos

    SpringBoot项目使用nacos kotlin demo见Gitte 一.引入依赖 提示:这里推荐使用2.2.3版本,springboot与nacos的依赖需要版本相同,否则会报错. maven ...

  6. OpenAPI使用(swagger3),Kotlin使用swagger3,Java使用swagger3,gradle、Maven使用swagger3

    OpenAPI使用(swagger3) demo见Gitte 一.背景及名词解释 OpenAPI是规范的正式名称.规范的开发工作于2015年启动,当时SmartBear(负责Swagger工具开发的公 ...

  7. Gradle错误提示:Java home supplied via ‘xxx.xxx.xxx‘ is invalid

    Gradle错误提示:Java home supplied via 'org.gradle.java.home' is invalid 描述:在使用idea采用gradle进行依赖的管理功能,当想切换 ...

  8. 查看Hotspot源码,查看java各个版本源码的网站,如何查看jdk源码

    java开发必知必会之看源码,而看源码的第一步则是找到源码

  9. java基本类型转换,随记

    java基本类型转换: double double 转 long double random = Math.round(Math.random()*10000); long l = new Doubl ...

最新文章

  1. 设计模式(2)工厂方法模式(Factory Method)
  2. Linux拜拜!微软给WSL加入GPU支持,Windows终于迎来命令行包管理工具
  3. java怎么运行class文件,面试必会
  4. 关于Update语句在不同数据库中的差别
  5. 第三章 dubbo内核之ioc源码解析
  6. log4net 记录日志到sqlserver
  7. python库(2)—— threading
  8. 基于数据库的分布式锁实现
  9. kickstart命令选项
  10. 前端学习(599):模拟移动设备
  11. Linux下的字符界面扫雷游戏
  12. 数学建模——SPSS的非参数检验
  13. 聚类分析方法的研究与应用综述
  14. 全球及中国SxS(遥控潜水器)行业商业模式分析及投资风险预测2022年版
  15. 人事面试java需要注意点_程序员hr面试注意事项
  16. 核心交换机与普通交换机的区别
  17. 软件开发的流程是怎样的?
  18. Selenium||解决给元素输入文本失败问题
  19. Android moudle库使用aar的方法
  20. c 语言奇数幻方代码,【C】——幻方算法(示例代码)

热门文章

  1. Android 网络连接状态的监控
  2. linux常用性能分析命令详解#TOP
  3. hbase 问题整理
  4. Tensorflow 2.0.0-alpha 安装 Linux系统
  5. [福大软工] W班 总成绩排行榜
  6. 原创:Docker在云家政的应用 谢绝复制粘贴内容
  7. 知识梳理——HTML篇
  8. DataAdapter对象
  9. 编写高质量代码改善C#程序的157个建议——建议87:区分WPF和WinForm的线程模型...
  10. c++ -- 构造函数与析构函数