Description

作为一个资深OIer,你被邀请到位于波兰的CDPR总部参观。但没想到你刚一到就遇到了麻烦。昆特牌的数据库发生了故障。原本昆特牌中有 k种卡牌和n 种阵营,为了平衡,每个阵营拥有的卡牌种数都是相等的,并且每个阵营的数据顺序排列。由于故障,卡牌数据被打乱了,每个阵营现在有ai 种卡牌。因为昆特牌即将迎来重大更新,每种牌的所属阵营并不重要,工程师只想尽快让每个阵营拥有相同数量的卡牌。由于数据库的结构原因,你每单位时间只能将一种牌向左边或右边相邻的一个阵营移动。作为OI选手,这自然是难不倒你,但作为一名卡牌游戏爱好者,你想知道最终的卡牌分布有多少种方案。两种方案不同当且仅当存在一种卡牌,它在两种方案中所属阵营不同。对998244353取模

Input

第一行一个整数T,表示数据组数。
接下来每组数据,第一行一个整数n ,第二行n个数,第i个数为ai ,意义见题目描述

Output

T行,每行一个数表示答案。

Sample Input

Sample Input1
3
3
2 1 3
3
1 2 3
3
3 2 1

Sample Input2
4
3
8 1 0
4
5 0 1 2
4
0 4 0 0
4
1 1 6 0

Sample Output

Sample Output1
3
9
9

样例解释
对于第一组数据,初始为{{1,2}{3}{4,5,6}}
移动结束后为
{{1,2}{3,4}{5,6}},{{1,2}{3,6}{4,5}},{{1,2}{3,5}{4,6}}

Sample Output2
1120
30
24
270

Data Constraint

思路

求均摊纸牌的方案数。
考虑贪心的过程,转移形成了一个DAG。在图上DP即可。

代码

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const int maxn=1005,maxm=1000005;
const ll mod=998244353;
ll a[maxn],pow[maxm];
ll power(ll x,ll k,ll mod)
{ll ans=1;x%=mod;while(k){if(k&1)ans=ans*x%mod;x=x*x%mod;k>>=1;}return ans;
}
ll c(ll n,ll m)
{ll ans=pow[m]*pow[n-m]%mod;ll inv=power(ans,mod-2,mod);return pow[n]*inv%mod;
}
int main()
{freopen("gwent.in","r",stdin);freopen("gwent.out","w",stdout);ll t,n;scanf("%lld",&t);pow[1]=1;for(int i=2; i<=1000000; i++) pow[i]=pow[i-1]*i%mod;while(t--){ll sum=0,ans=0,ans1,ans2,ans3=0;ll s=1,s1=1;scanf("%lld",&n);for(int i=1;i<=n;i++)scanf("%lld",&a[i]),sum+=a[i];sum/=n;for(int i=1;i<=n;i++){ans+=a[i]; ans1=ans-sum*(i-1);if(ans1-sum>0) s1=s1*c(ans1,ans1-sum)%mod;else if(ans1-sum==0) s=s*s1%mod,s1=1;else{ans2=sum*n-sum*(n-i-1)-ans;ans3=max(ans2,a[i+1]);s1=s1*c(ans3,sum-ans1)%mod;}}printf("%lld\n",s);}return 0;
}

【JZOJ A组】昆特牌相关推荐

  1. 【纪中模拟2018.11.02】【JZOJ5945】昆特牌

    题目链接:https://jzoj.net/senior/#main/show/5945 Limits TL: 1e3ms ML:512Mb Description 原本昆特牌中有$k$种卡牌和$n$ ...

  2. 昆特牌Online——客户端设计

    OpenSceneGraph介绍: OpenSceneGraph(以下简称OSG)是一个开源的三维引擎,被广泛的应用在可视化仿真.游戏.虚拟现实.科学计算.三维重建.地理信息.太空探索.石油矿产等领域 ...

  3. ACM_题目这么难,来局愉快的昆特牌吧

    题目这么难,来局愉快的昆特牌吧 Time Limit: 2000/1000ms (Java/Others) Problem Description: 小Z打比赛,然而比赛太难了,他坐在电脑面前被题淹没 ...

  4. JZOJ-senior-5945. 【NOIP2018模拟11.02】昆特牌(gwent)

    Time Limits: 1000 ms Memory Limits: 524288 KB Detailed Limits Description 作为一个资深OIer,你被邀请到位于波兰的CDPR总 ...

  5. 少年啊,来一发昆特吗(二)——昆特牌的触摸

    昆特牌在整个游戏中需要三种触摸形式,一种是初始发牌时的换牌阶段,点击可以更换牌(镶嵌到tableview中),二是正常打牌阶段的触摸,点击两次后,将牌打出,第三种是医生的复活技能效果,选择墓地中的牌将 ...

  6. jozj5945. 【NOIP2018模拟11.02】昆特牌

    5945. [NOIP2018模拟11.02]昆特牌 Description 作为一个资深OIer,你被邀请到位于波兰的CDPR总部参观.但没想到你刚一到就遇到了麻烦.昆特牌的数据库发生了故障.原本昆 ...

  7. 3D图形和网络编程的一次实践——昆特牌Online

    这是个游戏,曾经打算用这个来做团队项目的题目,但是后来大家选择了别的题目,所以这个项目并没有成为我们组的团队项目.后来我还是自己把这个游戏做完了,虽然并不是完整版. 想法来自15年波兰CDPR公司发售 ...

  8. 上古卷轴3晨风职业_巫师3:上古卷轴5老玩家,入手巫师3,体验昆特牌版“实验室”...

    今天小编入手了,期待已久的<巫师3>,而作为一个<上古卷轴5>的"老油条",奇趣君下面说一下,一个老滚5的"老油条"玩<巫师3&g ...

  9. Linux系统使用steamplay完美运行巫师之昆特牌:王权的陨落(Thronebreaker:The Witcher Tales)

    问题描述 使用steamplay运行巫师之昆特牌:王权的陨落,打开游戏会出现黑屏,无法进行游戏的情况. 注意: 此问题不仅在linux上存在,部分Windows系统也会出现此问题,是由于游戏依赖了Me ...

最新文章

  1. JS学习笔记之call、apply的用法
  2. KDE和GNOME的区别※切换
  3. AtCoder AGC030C Coloring Torus (构造)
  4. python调用外部程序 退出_2019-09-09 python调用外部程序
  5. Spring MVC 源码-运行调用阶段
  6. java编写学籍管理系统_java学籍管理系统源代码.doc
  7. (整理)REHL6.5_Yum安装Reids
  8. Linux fstab配置文件详解
  9. Python基础-基本语法
  10. excel合并两列内容_excel新手问题:怎么把两列数据合并到一起?用这个公式
  11. C#报表开发工具ReportViewer vs Stimulsoft Reports.Net
  12. Java-KoTime:接口耗时监测与邮件通知接口耗时情况
  13. 黑马程序员---java算法实现输出任意奇数维数独
  14. 文本检测最近文章检索(1)
  15. SAP中常见的Debug技巧(02)-跳过代码执行
  16. ssh免密登录服务器
  17. PVE安装ros系统
  18. GPU CPU NPU
  19. 手撸架构,Elasticsearch 面试25问
  20. JUC第六讲:ThreadLocal/InheritableThreadLocal详解/TTL-MDC日志上下文实践

热门文章

  1. Linux backtrace的实现原理
  2. 操作系统-进程控制块PCB-实验报告
  3. template.js模板渲染
  4. [导入]一个男人的自白
  5. 利用Python解决生物问题-批量获取最长转录本
  6. 顶级AI软件开发工具总结
  7. 如何将视频转换成MP4格式?可以用这几个方法!
  8. 高加水箱液位控制系统+MATLAB仿真
  9. java配合什么做前端_作为一个java程序员 ,前端的技术需要达到什么水平?
  10. 谈谈互联网企业的人员分工和角色管理