题目链接

戳我

\(Solution\)

我们将现在所要进行的数设为\(now\)

我们分情况讨论一下

  1. 他自己不翻倍
  2. 他自己翻倍

我们首先来看看\(1\)操作

如果要满足他对排名没有影响,那么不能进行翻倍的数只有\([\lceil\frac{now}{2}\rceil,now]\)。(我考场上不知道在干吗,写的是能进行翻倍的数,麻烦好多,常数也大)。我们假设这一段为\(cnt\)个,那么这一段的答案就是:

\[C_{n-cnt}^{k}
\]

再来看看\(2\)操作

如果我们要讲\(now*2\)要使得排名不变,那么\([now,now*2)\)则必须翻倍,将区间内的数射为res,其他的随便选那些数都可以。答案就是

\[C_{n-res}^{k-res}
\]

最后的答案就是

\[C_{n-res}^{k-res}+C_{n-cnt}^{k}
\]

\(Code\)

代码写的十分丑陋,毕竟是考场写的吗

#include<bits/stdc++.h>
#define int long long
#define rg register
#define file(x) freopen(x".in","r",stdin);freopen(x".out","w",stdout);
const int mod=998244353;
using namespace std;
int read(){
int x=0,f=1;char c=getchar();
while(c<'0'||c>'9') f=(c=='-')?-1:1,c=getchar();
while(c>='0'&&c<='9') x=x*10+c-48,c=getchar();
return f*x;
}
struct node {
int id,x;
}a[100010];
bool cmp(const node & a , const node & b ){
return a.x<b.x;
}
int b[100010],jc[100010],c[100010];
int ksm(int a,int b){
int ans=1;
while(b){
if(b&1)
ans=a*ans%mod;
a=a*a%mod;
b>>=1;
}
return ans;
}
main(){
file("sort");
int n=read(),k=read();
for(int i=1;i<=n;i++)
a[i].id=i,a[i].x=read();
sort(a+1,a+1+n,cmp);
jc[0]=1;
for(int i=1;i<=n;i++)
b[i]=a[i].x,jc[i]=jc[i-1]*i%mod;
for(int i=1;i<=n;i++){
int x=b[i]/2,ans=0;
if(b[i]&1)
x++;
int p=lower_bound(b+1,b+1+n,x)-b-1;
int j=lower_bound(b+1,b+1+n,b[i])-b-1;
int pp=n-j-1;
if(p+pp>=k)
ans+=jc[p+pp]*ksm(jc[k]*jc[p+pp-k]%mod,mod-2)%mod;
int ppp=max(lower_bound(b+1,b+1+n,b[i]*2)-b-1-j,1ll*1);
int kk=k-ppp;
if(kk>=0)
p=n-ppp,ans+=jc[p]*ksm(jc[kk]*jc[p-kk]%mod,mod-2)%mod;
c[a[i].id]=ans%mod;
}
for(int i=1;i<=n;i++)
cout<<c[i]<<endl;
return 0;
}

「PKUSC 2018」真实排名的更多相关文章

  1. LOJ #6432. 「PKUSC2018」真实排名(组合数)

    题面 LOJ #6432. 「PKUSC2018」真实排名 注意排名的定义 , 分数不小于他的选手数量 !!! 题解 有点坑的细节题 ... 思路很简单 , 把每个数分两种情况讨论一下了 . 假设它为 ...

  2. LOJ #2542. 「PKUWC 2018」随机游走(最值反演 + 树上期望dp + FMT)

    写在这道题前面 : 网上的一些题解都不讲那个系数是怎么推得真的不良心 TAT (不是每个人都有那么厉害啊 , 我好菜啊) 而且 LOJ 过的代码千篇一律 ... 那个系数根本看不出来是什么啊 TAT ...

  3. LOJ #2802. 「CCC 2018」平衡树(整除分块 + dp)

    题面 LOJ #2802. 「CCC 2018」平衡树 题面有点难看...请认真阅读理解题意. 转化后就是,给你一个数 \(N\) ,每次选择一个 \(k \in [2, N]\) 将 \(N\) 变 ...

  4. LOJ #2541. 「PKUWC 2018」猎人杀(容斥 , 期望dp , NTT优化)

    题意 LOJ #2541. 「PKUWC 2018」猎人杀 题解 一道及其巧妙的题 , 参考了一下这位大佬的博客 ... 令 \(\displaystyle A = \sum_{i=1}^{n} w_ ...

  5. LOJ #2540. 「PKUWC 2018」随机算法(概率dp)

    题意 LOJ #2540. 「PKUWC 2018」随机算法 题解 朴素的就是 \(O(n3^n)\) dp 写了一下有 \(50pts\) ... 大概就是每个点有三个状态 , 考虑了但不在独立集中 ...

  6. LOJ #2538. 「PKUWC 2018」Slay the Spire (期望dp)

    Update on 1.5 学了 zhou888 的写法,真是又短又快. 并且空间是 \(O(n)\) 的,速度十分优秀. 题意 LOJ #2538. 「PKUWC 2018」Slay the Spi ...

  7. 「TJOI 2018」教科书般的亵渎

    「TJOI 2018」教科书般的亵渎 题目描述 小豆喜欢玩游戏,现在他在玩一个游戏遇到这样的场面,每个怪的血量为 \(a_i\) ,且每个怪物血量均不相同, 小豆手里有无限张"亵渎" ...

  8. 「TJOI 2018」游园会 Party

    「TJOI 2018」游园会 Party 题目描述 小豆参加了 \(NOI\) 的游园会,会场上每完成一个项目就会获得一个奖章,奖章只会是 \(N, O, I\) 的字样. 在会场上他收集到了 \(K ...

  9. 「PKUSC2018」真实排名(排列组合,数学)

    前言 为什么随机跳题会跳到这种题目啊? Solution 我们发现可以把这个东西分情况讨论: 1.这个点没有加倍 这一段相同的可以看成一个点,然后后面的都可以. 这一段看成一个点,然后前面的不能对他造 ...

随机推荐

  1. wpf学习笔记(1)

    wpf常用控件 0x01. 常用布局控件 1.Canvas 不会对子控件施加任何帮助,也不会施加任何限制 2.DockPanel 可以让子控件贴靠在自己四条边的任意一边 ,最后一个子控件充满剩余区域 ...

  2. RabbitMQ入门教程(三):Hello World

    原文:RabbitMQ入门教程(三):Hello World 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog. ...

  3. RabbitMQ入门教程(二):简介和基本概念

    原文:RabbitMQ入门教程(二):简介和基本概念 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn ...

  4. KVM安装配置笔记

    系统环境centos6.6 一.KVM安装前系统相关操作: (1)修改内核模式为兼容内核启动 # grep -v "#" /etc/grub.confdevice (hd0) HD ...

  5. Django新建第一个投票应用

    1:在Pycharm的命令端口,确保执行文件路径是与mysite同级 $ python3 manage.py startapp polls 系统会自动生成polls应用的目录,其结构如下 polls/ ...

  6. 架构师必备,带你弄清混乱的JAVA日志体系!

    作者:孤独烟 出处:http://rjzheng.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任 ...

  7. Nginx Windows下安装使用及权重分配

    内容目录 Nginx 下载启动Nginx关闭NginxNginx使用注意事项使用Nginx代理服务器做负载均衡Nginx配置静态资源Nginx权重分配方式Nginx负载均衡参数描述写在最后 Nginx ...

  8. php基于websocket实现的在线聊天室

    听说websocket技术可以实现 1.

  9. asp.net mvc + vue.js + axios.js

    1.新建一个 MVC 应用程序 2.右键解决方案 添加VUE 3.搜索vue 1.安装axios.js ,用于数据请求,get , post axios

  10. elementUI中的el-xxx标签解释

    点击跳转地址:https://blog.csdn.net/Tom__cy/article/details/89680067 el-col :整体,el-container: 主体区域el-toolti ...