蓝桥杯试题 算法训练 Sereja and Equality (已AC)

简介: 蓝桥杯试题 算法训练 Sereja and Equality (已AC)

蓝桥杯试题 算法训练 Sereja and Equality


资源限制


时间限制:1.0s 内存限制:512.0MB


问题描述


 (注:这是codechef上的官方翻译)

 佳佳称两个长度为n的数组A,B相似,如果对于所有i(1≤i≤n),满足C(A,Ai)=C(B,Bi)。其中C(X,x)等于满足X[j]

 对于两个排列P1,P2,佳佳定义函数F(P1,P2)等于满足P1[l…r]相似于P2 [l…r] (1≤l≤r≤n)并且P1[l…r]包含不超过E个逆序对的数对(l,r)的数目。

 现在佳佳对下面这个问题发生了兴趣:对P1,P2取遍所有n个元素的排列F(P1,P2)的总和是多少。


输入格式


 输入数据的第一行包含一个整数T——测试数据的组数。

 对于每组测试数据,仅包含一行两个整数n,E。


输出格式


 对于每组测试数据,输出一行表示结果。答案对109+7取模。


样例输入

4

2 2

2 1

2 0

1 1

样例输出

10

10

9

1


题解

当比较区间长度定下来之后方案数就跟[ l , r ] 这个区间的位置无关了。

于是我们可以直接枚举区间的长度来计算贡献。

但是光这样是不够的。

我们需要递推出1~i 的所有排列中逆序对数为j jj的排列种类数。

这个貌似就是记录一个前缀和就行了。

f [ i ] [ j ] = ∑ f [ i − 1 ] [ k ] 且j − i + 1 ≤ k ≤ j

证明就是考虑已经处理好了1~i − 1的排列。

在所有位置插入i ii的贡献。

这个思想参见[HAOI2009]逆序对数列。

剩下的递推就是简单组合数学了。


代码


#include<bits/stdc++.h>
#define N 505
#define mod 1000000007
using namespace std;
inline int read(){
  int ans=0;
  char ch=getchar();
  while(!isdigit(ch))ch=getchar();
  while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
  return ans;
}
int C[N][N],f[N][N*N],T,n,k,ans,fac[N];
inline void init(){
  fac[0]=1;
  for(int i=1;i<=500;++i)fac[i]=1ll*fac[i-1]*i%mod;
  for(int i=1;i<=500;++i)C[i][0]=C[i][i]=1,C[i][1]=i;
  for(int i=2;i<=500;++i)for(int j=1;j<=i;++j){
    C[i][j]=C[i-1][j]+C[i-1][j-1];
    if(C[i][j]>=mod)C[i][j]-=mod;
  }
  int sum=0;
  f[1][0]=1;
  for(int i=2;i<=500;++i){
    sum=0;
    for(int j=0;j<=(i-1)*i/2;++j){
      sum+=f[i-1][j];
      if(sum>=mod)sum-=mod;
      f[i][j]=sum;
      if(j+1-i>=0)sum=(sum-f[i-1][j+1-i]+mod)%mod;
    }
  }
  for(int i=2;i<=500;++i)for(int j=1;j<=(i-1)*i/2;++j){
    f[i][j]+=f[i][j-1];
    if(f[i][j]>=mod)f[i][j]-=mod;
  }
}
int main(){
  init(),T=read();
  while(T--){
    n=read(),k=read(),ans=0;
    for(int i=1;i<=n;++i){
      int tmp=1ll*C[n][i]*C[n][i]%mod*f[i][min(i*(i-1)/2,k)]%mod*fac[n-i]%mod*fac[n-i]%mod*(n-i+1)%mod;
      ans+=tmp;
      if(ans>=mod)ans-=mod;
    }
    printf("%d\n",ans);
  }
  return 0;
}


相关文章
|
9天前
|
算法 测试技术 C++
【动态规划算法】蓝桥杯填充问题(C/C++)
【动态规划算法】蓝桥杯填充问题(C/C++)
|
2天前
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
11 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
4月前
|
存储 机器学习/深度学习 算法
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
46 3
|
7天前
|
机器学习/深度学习 算法 决策智能
【机器学习】揭秘深度学习优化算法:加速训练与提升性能
【机器学习】揭秘深度学习优化算法:加速训练与提升性能
|
2天前
|
人工智能 Python
蓝桥杯练习题(四):Python组之历届试题三十题
关于蓝桥杯Python组历届试题的三十个练习题的总结,包括题目描述、输入输出格式、样例输入输出以及部分题目的解题思路和代码实现。
6 0
蓝桥杯练习题(四):Python组之历届试题三十题
|
9天前
|
算法 Java C++
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
【贪心算法】算法训练 ALGO-1003 礼物(C/C++)
|
2天前
|
Python
蓝桥杯练习题(一):Python组之入门训练题
这篇文章是关于蓝桥杯Python组的入门训练题,包括Fibonacci数列、圆的面积、序列求和和A+B问题的具体代码实现和样例输出。
20 0
|
9天前
|
算法 C++
蓝桥 算法训练 共线(C++)
蓝桥 算法训练 共线(C++)
|
3月前
knn增强数据训练
【7月更文挑战第27天】
30 10
|
3月前
|
数据采集 编解码 人工智能
破解ChatGPT惊人耗电!DeepMind新算法训练提效13倍,能耗暴降10倍
【7月更文挑战第19天】DeepMind的JEST算法革新AI训练,提升效率13倍,节能10倍。通过联合数据批次选择,预训练指导及多分辨率训练,优化资源利用,降低能耗。实验显示性能提升,达到SOTA水平,但实施需大量资源,依赖优质参考模型。[论文链接](https://arxiv.org/pdf/2406.17711)
60 10