news 2026/5/23 0:48:45

打卡信奥刷题(2606)用C++实现信奥题 P2476 [SCOI2008] 着色方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2606)用C++实现信奥题 P2476 [SCOI2008] 着色方案

P2476 [SCOI2008] 着色方案

题目描述

nnn个木块排成一行,从左到右依次编号为111nnn

你有kkk种颜色的油漆,第iii种颜色的油漆足够涂cic_ici个木块。

所有油漆刚好足够涂满所有木块,即∑i=1kci=n\sum_{i=1}^kc_i=ni=1kci=n

由于相邻两个木块涂相同色显得很难看,所以你希望统计任意两个相邻木块颜色不同的着色方案。

由于答案可能很大,请输出对109+710^9+7109+7取模的结果。

输入格式

第一行,一个整数kkk,表示颜色数量。

第二行kkk个整数c1,c2,…,ckc_1,c_2,\dots,c_kc1,c2,,ck,表示每种颜色能够涂木块的个数。

输出格式

一行一个整数,表示答案对109+710^9+7109+7取模的结果。

输入输出样例 #1

输入 #1

3 1 2 3

输出 #1

10

输入输出样例 #2

输入 #2

5 2 2 2 2 2

输出 #2

39480

输入输出样例 #3

输入 #3

10 1 1 2 2 3 3 4 4 5 5

输出 #3

85937576

说明/提示

  • 对于50%50\%50%的数据,1≤k≤51 \leq k \leq 51k51≤ci≤31 \leq c_i \leq 31ci3
  • 对于100%100\%100%的数据,1≤k≤151 \leq k \leq 151k151≤ci≤51 \leq c_i \leq 51ci5

C++实现

#include<bits/stdc++.h>#defineRGregister#defineILinline#defineFill(a,b)memset(a,b,sizeof(a))usingnamespacestd;typedeflonglongll;constintZsy(1e9+7);IL llInput(){RG ll x=0,z=1;RGcharc=getchar();for(;c<'0'||c>'9';c=getchar())z=c=='-'?-1:1;for(;c>='0'&&c<='9';c=getchar())x=(x<<1)+(x<<3)+(c^48);returnx*z;}intk,c[16],C[80][80],f[20][80],sum[16];ILvoidPrepare(){C[0][0]=1;for(RGinti=1;i<=75;++i){C[i][0]=1;for(RGintj=1;j<=75;++j)C[i][j]=(C[i-1][j]+C[i-1][j-1])%Zsy;}}intmain(RGintargc,RGchar*argv[]){Prepare();k=Input();for(RGinti=1;i<=k;++i)c[i]=Input(),sum[i]=sum[i-1]+c[i];f[1][c[1]-1]=1;for(RGinti=1;i<k;++i)for(RGintj=0;j<sum[i];++j){if(!f[i][j])continue;for(RGinta=1;a<=c[i+1];++a)for(RGintb=0;b<=a&&b<=j;++b){RGintret=1LL*f[i][j]*C[c[i+1]-1][a-1]%Zsy*C[j][b]%Zsy;ret=1LL*ret*C[sum[i]+1-j][a-b]%Zsy;(f[i+1][j+c[i+1]-a-b]+=ret)%=Zsy;}}printf("%d\n",f[k][0]);return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 16:23:44

matlab/simulink的复合电源超级电容能量管理仿真策略电动汽车 基于模糊控制的能量控制策略

matlab/simulink的复合电源超级电容能量管理仿真策略电动汽车 基于模糊控制的能量控制策略。 是为数不多的纯数学模型纯simulink&#xff08;如下图一&#xff09;搭建的复合电源仿真模型。 电池用二阶RC等效电路模型 运行结果良好如下图三 直接上手搞电动汽车能量管理仿真这事…

作者头像 李华
网站建设 2026/5/19 16:33:31

编程语言工具链简介

这是一个触及了编程语言生态系统的核心问题。除了前面提到的编译器、包管理器等&#xff0c;一个完整的开发工具链还包括构建/自动化工具、测试框架、文档生成器、代码格式化/检查工具等。 由于语言众多&#xff0c;将它们分为几个类别&#xff0c;并选取代表语言来阐述其工具链…

作者头像 李华
网站建设 2026/5/14 5:09:43

Eureka 在大数据环境中的性能优化技巧

Eureka 在大数据环境中的性能优化技巧&#xff1a;从痛点到实战 引言&#xff1a;大数据环境下&#xff0c;Eureka 为什么会「卡」&#xff1f; 作为 Netflix 开源的服务发现组件&#xff0c;Eureka 凭借「简单、可靠、去中心化」的设计&#xff0c;成为微服务架构中的「流量入…

作者头像 李华
网站建设 2026/5/10 12:36:39

千万注意!实验室改造的5大陷阱

实验室改造&#xff0c;千万别踩这5个大坑&#xff01;朋友们&#xff0c;你们有没有遇到过这种情况&#xff1f;实验室用了好些年&#xff0c;设备有点旧了&#xff0c;空间也不太够用&#xff0c;想改造升级一下&#xff0c;结果一动手才发现&#xff0c;这里头的水&#xff…

作者头像 李华
网站建设 2026/4/30 17:24:11

我发现流式数据签名验证慢 后来才知道用crypto流式HMAC加速

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 目录家人们谁懂啊&#xff01;Node.js这玩意儿居然能帮我抢到演唱会门票&#xff1f;&#xff01; 一、Node.js到底是啥&#xf…

作者头像 李华