博客
关于我
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/

你可能感兴趣的文章
mysql操作数据表的命令_MySQL数据表操作命令
查看>>
mysql操作日志记录查询_如何使用SpringBoot AOP 记录操作日志、异常日志?
查看>>
MySQL支持的事务隔离级别,以及悲观锁和乐观锁的原理和应用场景?
查看>>
mysql支持表情
查看>>
MySQL支撑百万级流量高并发的网站部署详解
查看>>
MySQL改动rootpassword的多种方法
查看>>
mysql数据分组索引_MYSQL之索引配置方法分类
查看>>
mysql数据取差,mysql屏蔽主外键关联关系
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
Mysql数据库 InnoDB存储引擎中Master Thread的执行流程
查看>>
MySQL数据库 范式
查看>>
Mysql数据库B-Tree索引
查看>>
mysql数据库io空闲_mysql数据库磁盘io高的排查
查看>>
mysql数据库root密码忘记,查看或修改的解决方法
查看>>
MySQL数据库SQL注入靶场sqli通关实战(附靶场安装包)
查看>>
MYSQL数据库下载安装(Windows版本)
查看>>
MySQL数据库与Informix:能否创建同名表?
查看>>
mysql数据库中的数据如何加密呢?mysql8.0自带新特性
查看>>
MySQL数据库优化
查看>>