蓝桥杯试题 算法训练 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;
}


相关文章
|
5月前
|
算法 Java Serverless
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-444 算法训练 求和问题
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-444 算法训练 求和问题
50 1
|
4月前
|
存储 机器学习/深度学习 算法
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
第十五届蓝桥杯pb组国赛E题[马与象] (15分)BFS算法 详解
42 3
|
3月前
knn增强数据训练
【7月更文挑战第27天】
29 10
|
3月前
|
数据采集 编解码 人工智能
破解ChatGPT惊人耗电!DeepMind新算法训练提效13倍,能耗暴降10倍
【7月更文挑战第19天】DeepMind的JEST算法革新AI训练,提升效率13倍,节能10倍。通过联合数据批次选择,预训练指导及多分辨率训练,优化资源利用,降低能耗。实验显示性能提升,达到SOTA水平,但实施需大量资源,依赖优质参考模型。[论文链接](https://arxiv.org/pdf/2406.17711)
57 10
|
3月前
knn增强数据训练
【7月更文挑战第28天】
23 2
|
2月前
|
算法 搜索推荐
支付宝商业化广告算法问题之基于pretrain—>finetune范式的知识迁移中,finetune阶段全参数训练与部分参数训练的效果如何比较
支付宝商业化广告算法问题之基于pretrain—>finetune范式的知识迁移中,finetune阶段全参数训练与部分参数训练的效果如何比较
|
3月前
|
人工智能 边缘计算 算法
破解ChatGPT惊人耗电!DeepMind新算法训练提效13倍,能耗暴降10倍
【7月更文挑战第20天】DeepMind unveils Switch Transformer, revolutionizing AI energy consumption. This novel algorithm boosts training efficiency by 13x and slashes energy use by 10x compared to ChatGPT, marking a significant leap towards eco-friendly AI.
40 2
|
2月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)
|
4月前
|
机器学习/深度学习 算法
**反向传播算法**在多层神经网络训练中至关重要,它包括**前向传播**、**计算损失**、**反向传播误差**和**权重更新**。
【6月更文挑战第28天】**反向传播算法**在多层神经网络训练中至关重要,它包括**前向传播**、**计算损失**、**反向传播误差**和**权重更新**。数据从输入层流经隐藏层到输出层,计算预测值。接着,比较预测与真实值计算损失。然后,从输出层开始,利用链式法则反向计算误差和梯度,更新权重以减小损失。此过程迭代进行,直到损失收敛或达到训练次数,优化模型性能。反向传播实现了自动微分,使模型能适应训练数据并泛化到新数据。
56 2
|
4月前
|
分布式计算 算法 Java
阿里云ODPS PySpark任务使用mmlspark/synapseml运行LightGBM进行Boosting算法的高效训练与推理
阿里云ODPS PySpark任务使用mmlspark/synapseml运行LightGBM进行Boosting算法的高效训练与推理
下一篇
无影云桌面