博客
关于我
P5367 【模板】康托展开
阅读量:229 次
发布时间:2019-02-28

本文共 996 字,大约阅读时间需要 3 分钟。

题目描述

求1\sim N1∼N的一个给定全排列在所有1\sim N1∼N全排列中的排名。结果对998244353998244353取模。

输入格式

第一行一个正整数NN。

第二行NN个正整数,表示1\sim N1∼N的一种全排列。

输出格式

一行一个非负整数,表示答案对998244353998244353取模的值。

输入输出样例

输入 #1 复制
3
2 1 3
输出 #1 复制
3
输入 #2 复制
4
1 2 4 3
输出 #2 复制
2
说明/提示
对于10%10%数据,1\le N\le 101≤N≤10。

对于50%50%数据,1\le N\le 50001≤N≤5000。

对于100%100%数据,1\le N\le 10000001≤N≤1000000。

思路:用树状数组+康托展开(百度)

#include 
typedef long long ll;const ll mod = 998244353;ll a[1000005];ll b[1000005];ll c[1000005];int n;void init(int n){//pretreatment b[0] = 1; for(int i = 1;i <= n;i++){ b[i] = (b[i-1]*i)%mod; } return;}void update(int x,int k){ for(int i = x;i <= n;i += i&-i){ c[i] += k; }}ll query(int x){ ll ans = 0; for(int i = x;i > 0;i -= i&-i){ ans += c[i]; } return ans;}int main(){ ll ans = 0; scanf("%d",&n); init(n); for(int i = 1;i <= n;i++){ scanf("%lld",a+i); update(i,1); } for(int i = 1;i <= n;i++){ ll t = query(a[i])-1;//减去自己本身 ans = (ans+(t*b[n-i])%mod+mod)%mod; update(a[i],-1); } printf("%lld\n",ans+1); return 0;}

转载地址:http://piqp.baihongyu.com/

你可能感兴趣的文章
n = 3 , while n , continue
查看>>
n 叉树后序遍历转换为链表问题的深入探讨
查看>>
N!
查看>>
N-Gram的基本原理
查看>>
n1 c语言程序,全国青少年软件编程等级考试C语言经典程序题10道七
查看>>
Nacos Client常用配置
查看>>
nacos config
查看>>
Nacos Config--服务配置
查看>>
Nacos Derby 远程命令执行漏洞(QVD-2024-26473)
查看>>
Nacos 与 Eureka、Zookeeper 和 Consul 等其他注册中心的区别
查看>>
Nacos 单机集群搭建及常用生产环境配置 | Spring Cloud 3
查看>>
Nacos 启动报错[db-load-error]load jdbc.properties error
查看>>
Nacos 报Statement cancelled due to timeout or client request
查看>>
Nacos 注册服务源码分析
查看>>
Nacos 融合 Spring Cloud,成为注册配置中心
查看>>
Nacos-注册中心
查看>>
Nacos2.X 源码分析:为订阅方推送、服务健康检查、集群数据同步、grpc客户端服务端初始化
查看>>
Nacos2.X 配置中心源码分析:客户端如何拉取配置、服务端配置发布客户端监听机制
查看>>
Nacos2.X源码分析:服务注册、服务发现流程
查看>>
NacosClient客户端搭建,微服务注册进nacos
查看>>