一个小问题:题意中关于$b_{i}$的顺序只需要单调不降即可,相同时可任意选择

考虑$i$优于$j$的条件,即$val_{i}\ge val_{j}+[i>j]$,并记$del_{i,j}=\max(a_{i}+[i<j]-a_{j},0)$

先考虑暴力$o(n!)$枚举最终的排名排名$p_{i}$(其中$p_{1}$为第一名),并判定其是否合法

根据题目的描述,即要求存在$b_{i}$,满足:

1.$\sum_{i=1}^{n}b_{i}=m$且$b_{p_{n}}\le b_{p_{n-1}}\le ...\le b_{p_{1}}$

2.$\forall 1\le i<n,a_{p_{i}}+b_{p_{i}}\ge a_{p_{i+1}}+b_{p_{i+1}}+[p_{i}>p_{i+1}]$

3.$\forall 1\le i<j\le n,a_{p_{j}}+b_{p_{j}}\ge a_{p_{i}}+[p_{j}>p_{i}]$

注意到除去$\sum_{i=1}^{n}b_{i}=m$以外,其余条件都限制的是$b_{i}$之差,同时增加$b_{p_{1}}$并不影响后者,换言之每一个$b_{i}$一定取其所有限制条件中的最小值,最终通过调整(增大)$b_{p_{1}}$使其恰等于$m$即可

更具体的来说,对于$1\le i<n$时,满足$b_{p_{i}}=\max(\max_{1\le j<i}del_{p_{j},p_{i}},b_{p_{i+1}}+del_{p_{i+1},p_{i}})$

(特别的,$b_{p_{n}}=\max_{i=1}^{n}del_{i,p_{n}}$)

求出$b_{i}$后,将其累加并判定是否小于等于$m$即可

关于这个的计算,可以从后往前,前者的$p_{j}$即所有未出现的元素,同时由于$[p_{i}>p_{j}]$的影响至多为1,必然是在$a_{p_{j}}$最大的基础上选择$p_{j}$最小的,可以$o(2^{n})$预处理出

综上,即得到一个$o(n!)$的做法,显然无法通过

事实上,对于$1\le i<n$,还满足$\max_{1\le j<i}del_{p_{j},p_{i}}\le b_{p_{i+1}}+del_{p_{i+1},p_{i}}$,换言之,即$\max$一定选择后者

证明比较简单,假设前面最大值在$p_{j}=k$处取到,那么有$b_{p_{i+1}}\ge del_{k,p_{i+1}}$,且前者恰为$del_{k,p_{i}}$

代入后,若前者结果为0,则必然小于等于后者,后者去除max后单调不递增,因此都可以去除,取出后对其抵消即得到$[p_{i}>p_{k}]\le [p_{i+1}>k]+[p_{i}>p_{i+1}]$

对其进行分类讨论,不难得到该式恒成立,即得证

最终,即有$b_{p_{i}}=b_{p_{i+1}}+del_{p_{i+1},p_{i}}$(这里可能还需要从后往前归纳一下,且$b_{p_{n}}$不变),那么即有$\sum_{i=1}^{n}b_{i}=\sum_{i=1}^{n-1}i\cdot del_{p_{i+1},p_{i}}+n\max_{1\le i\le n}del_{i,p_{n}}$

现在,即可状压dp,即$f_{S,i,j}$表示满足以下条件的排列数:$\{p_{1},p_{2},...,p_{|S|}\}=S$,$p_{|S|}=i$且$1\le i\le |S|$在上式中和为$j$

转移枚举下一个元素,即$f_{S\cup\{x\},x,j+|S|del_{x,i}}=\sum_{x\notin S}f_{S,i,j}$,最后再计算$n\max_{1\le i\le n}del_{i,p_{n}}$对答案的影响即可(即要求$j\le m-n\max_{1\le i\le n}del_{i,p_{n}}$)

最终计算复杂度为$o(n^{2}m2^{n})$,可以通过

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 13
4 #define M 505
5 #define ll long long
6 int n,m,a[N],b[N],tot[1<<N];
7 ll ans,f[1<<N][N][M];
8 int del(int x,int y){
9 return max(a[x]+(y>x)-a[y],0);
10 }
11 int main(){
12 scanf("%d%d",&n,&m);
13 for(int i=0;i<n;i++)scanf("%d",&a[i]);
14 for(int i=0;i<(1<<n);i++)tot[i]=tot[i>>1]+(i&1);
15 for(int i=0;i<n;i++)f[1<<i][i][0]=1;
16 for(int i=1;i<(1<<n);i++)
17 for(int j=0;j<n;j++)
18 if (i&(1<<j)){
19 for(int x=0;x<n;x++)
20 if (!(i&(1<<x))){
21 int s=tot[i]*del(x,j);
22 for(int k=s;k<=m;k++)f[i^(1<<x)][x][k]+=f[i][j][k-s];
23 }
24 }
25 int mx=0;
26 for(int i=1;i<n;i++)
27 if (a[i]>a[mx])mx=i;
28 for(int i=0;i<n;i++)
29 for(int j=0;j<=m-n*del(mx,i);j++)ans+=f[(1<<n)-1][i][j];
30 printf("%lld",ans);
31 }

[loj3503]滚榜的更多相关文章

  1. [TJOI2019]甲苯先生的滚榜——非旋转treap

    题目链接: [TJOI2019]甲苯先生的滚榜 要求维护一个二维权值的集合并支持单点修改,用平衡树维护即可. 因为$n\le 10^6$但$m\le 10^5$,所以最多只有$10^5$个人被操作. ...

  2. 洛谷P5338 [TJOI2019]甲苯先生的滚榜

    原题链接洛谷P5338 [TJOI2019]甲苯先生的滚榜 题目描述 甲苯先生在制作一个online judge,他发现做比赛的人们很关心自己的排名(显而易见),在acm赛制的比赛中,如果通过题目数量 ...

  3. LG5338/BZOJ5509/LOJ3105 「TJOI2019」甲苯先生的滚榜 Treap

    问题描述 LG5338 LOJ3105 BZOJ5509 题解 建立一棵\(\mathrm{Treap}\),把原来的\(val\)换成两个值\(ac,tim\) 原来的比较\(val_a<va ...

  4. BZOJ5509: [Tjoi2019]甲苯先生的滚榜

    题解 开n个平衡树对每个AC数维护罚时,然后不同AC数用树状数组维护即可. 其实挺好写的...就是评测的时候评的巨久... #include <bits/stdc++.h> using n ...

  5. 【题解】Luogu P5338 [TJOI2019]甲苯先生的滚榜

    原题传送门 这题明显可以平衡树直接大力整,所以我要说一下线段树+树状数组的做法 实际线段树+树状数组的做法也很暴力 我们先用树状数组维护每个ac数量有多少个队伍.这样就能快速求出有多少队伍ac数比现在 ...

  6. 「TJOI2019」甲苯先生的滚榜

    题目链接 问题分析 参照数据范围,我们需要一个能够在\(O(n\log n)\)复杂度内维护有序数列的数据结构.那么平衡树是很好的选择.参考程序中使用带旋Treap. 参考程序 #pragma GCC ...

  7. luogu P5338 [TJOI2019]甲苯先生的滚榜

    传送门 首先,排名系统,一看就知道是原题,可以上平衡树来维护 然后考虑一种比较朴素的想法,因为我们要知道排名在一个人前面的人数,也就是AC数比他多的人数+AC数一样并且罚时少的人数,所以考虑维护那两个 ...

  8. 百度音乐api

    百度音乐全接口 会利用使用接口找歌简单又快捷 http://tingapi.ting.baidu.com/v1/restserver/ting 获取方式:GET 参数:format=json或xml& ...

  9. ACM退役记&&回忆录

    ACM退役记 2017.9.19星期二,"九一八事变"八十六年后的第二天,永远记住这个日子,刚好是我报名ACM到现在,刚好满一年,而今天正是我注册杭州电子科技大学OJ的时间(就是这 ...

随机推荐

  1. 原生JS实现简单留言板功能

    原生JS实现简单留言板功能,实现技术:css flex,原生JS. 因为主要是为了练手js,所以其中布局上的一些细节并未做处理. <!DOCTYPE html> <html lang ...

  2. ElasticSearch IK热词自动热更新原理与Golang实现

    热更新概述 ik分词器本身可以从配置文件加载扩张词库,也可以从远程HTTP服务器加载. 从本地加载,则需要重启ES生效,影响比较大.所以,一般我们都会把词库放在远程服务器上.这里主要有2种方式: 借助 ...

  3. java课堂测试3第一部分(未完善)

    package test3;import java.util.*; public class Grade2 { static String[][] mis=new String[500][4]; // ...

  4. 洛谷luogu3957跳房子(单调队列优化)

    QwQ被普及组的题折磨的死去活来. 硬是卡线段树,没卡过QwQ oi生涯,第一道正经的单调队列dp题 进入正题 题目大意: 其中\(n \le 500000\) 看到这个题的第一感觉就是二分金币数 很 ...

  5. ToString()字符串转换你用正确了吗?

    前言 在开发中,ToString()这个方法太方便了,以致于误解大家转换时都是直接Object.ToString()直接转换, 其实不然, 一般都是转之前先判断是否为null后再进行转换,否则会直接报 ...

  6. AgileConfig 轻量级配置中心 1.5 发布 - 支持多环境配置

    AgileConfig 从发布到现在,收到不同学的 issue 说需要多环境的支持.也就是一个应用在不同的环境下可以配置不同的配置项.这是一个非常有用的功能,就跟我们开发的时候会设置多个 appset ...

  7. 【数据结构与算法Python版学习笔记】目录索引

    引言 算法分析 基本数据结构 概览 栈 stack 队列 Queue 双端队列 Deque 列表 List,链表实现 递归(Recursion) 定义及应用:分形树.谢尔宾斯基三角.汉诺塔.迷宫 优化 ...

  8. UltraSoft - Alpha - Scrum Meeting 1

    Date: Apr 06th, 2020. 会议内容为讨论功能规格书和技术规格书的撰写. Scrum 情况汇报 进度情况 组员 负责 昨日进度 后两日任务 CookieLau PM.后端 进行Djan ...

  9. RF射频传输,原理介绍,三分钟看懂!发射功率、接收灵敏度详解!

    射频是什么? 官方说法:RF,Radio Frequency. (不懂的人,看了还是不懂,不过对于物联网行业的开发工程师.产品经理和项目经理,还是有需要对射频有个基础了解的.) 燚智能解读: 两个人, ...

  10. 转:VIVADO使用技巧:设置DCI与内部参考电压

    本文转自:Vivado使用技巧(12):设置DCI与内部参考电压 - 灰信网(软件开发博客聚合) (freesion.com) DCI与内部参考电压 Xilinx FPGA提供了DCI(Digital ...