易小侠 2022-01-25 16:03 采纳率: 93.9%
浏览 45
已结题

用C语言解决一个抽签问题

抽签
X星球要派出一个5人组成的观察团前往W星。

其中:

A国最多可以派出4人。

B国最多可以派出2人。

C国最多可以派出2人。

依次到W
那么最终派往W星的观察团会有多少种国别的不同组合呢?

怎样编写程序

  • 写回答

3条回答 默认 最新

  • yyfhz 2022-01-25 17:50
    关注

    这题目应该是这么个意思:有W个国家,每个国家有a[i] (i=1,...,w)个人,需要选P个人组团,问有多少不同的国家组合方式。

    第一种解法是准备一个长度为W的数组,从0000...00开始递增,其中第i 个元素如果增加到a[i]+1则向前进位。等全部递增完了也就有结果了。
    需要内存空间W,耗时a[1]a[2]...*a[W]。

    第2种解法是用函数f(P,a{n})表示n个国家,每个国家有a[i]个人,共需要抽P个人的不同国家的抽法数量。
    则显然有f(0,a{n})=1,f{1,a{n})=n,以及f(P,a{1})=1 (如果a{1}>=P)和f(P,a{1})=0(如果a[1]<P)
    然后如果我们已知f(P,a{n}),则在此基础上增加一个国家,有
    f(P,a{n+1})=f(P,a{n})+f(P-1,a{n})+f(P-2,a{n})+...+f(P-min(P,a[n+1]), a{n})
    所以可以构造一个(W+1)(P+1)的矩阵C[0..W][0..P],先填好
    C[0,1]=1,..., C[0,W]=1,
    C[1,1]=1,...,C[1,W]=W,
    C[1,0]=0,...C[P,0]=0,
    C[1,1]=1,C[2,1]=1,...C[a[1],1]=1,C[a[1]+1,1]=0,...C[P,1]=0
    然后用上面的递推公式一列一列的算过去,直到C[P,W]。
    需要内存空间W
    P,耗时PWmax(a[i])

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月4日
  • 已采纳回答 1月27日
  • 创建了问题 1月25日

悬赏问题

  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100