Number Of Permutations
思路:利用容斥,首先所有可能的排列肯定是
fac[n]
,然后可能会有三种 bad 的情况:①第一个元素的排列是非递减
②第二种是第二个元素的排列是非递减
③这两个可能出现的重叠情况,意思就是说同时导致①②成立
这个时候我们利用容斥的思想,用
fac[n]-①-②+③
即可我们把所有的
pair
按照第一个元素优先排列的方式把所有的pair
sort 一下( sort 对pair
的排序方式是默认第一个元素优先的),这个时候我们就保证了所有pair
的第一个元素组成的排列的肯定是一个不严格递增的排列求③的时候需要注意的一点是,在已经按照第一个元素排完序之后,如果存在
s[i+1].se<s[i].se
,那么就表示不会有第三种情况发生因为s[i].fi<=s[i+1].fi
所以如果按照第二个元素非降序排序的话,就会导致s[i+1].fi<s[i].fi
,所以,如果出现这种情况则表明③=0
代码:
// Created by CAD on 2019/8/23.
#include <bits/stdc++.h>
#define se second
#define pii pair<int,int>
#define ll long long
using namespace std;
const int mod=998244353;
const int maxn=3e5+5;
pii s[maxn];
ll fac[maxn];
map<pii,int >ab;
map<int,int>a,b;
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
int n;cin>>n;
fac[0]=1;
for(int i=1;i<=n;++i)
fac[i]=fac[i-1]*i%mod;
for(int i=1;i<=n;++i)
{
int x,y;
cin>>x>>y;
a[x]++,b[y]++,ab[{x,y}]++;
s[i]=make_pair(x,y);
}
sort(s+1,s+n+1);
ll ans=fac[n],temp=1;
for(auto i:a)
temp=temp*fac[i.se]%mod;
ans=(ans-temp+mod)%mod,temp=1;
for(auto i:b)
temp=temp*fac[i.se]%mod;
ans=(ans-temp+mod)%mod,temp=1;
for(auto i:ab)
temp=temp*fac[i.se]%mod;
for(int i=1;i<n;++i)
if(s[i+1].se<s[i].se) temp=0;
ans=(ans+temp)%mod;
cout<<ans<<endl;
return 0;
}
Number Of Permutations的更多相关文章
- D. Number Of Permutations 符合条件的排列种类
D. Number Of Permutations time limit per test 2 seconds memory limit per test 256 megabytes input st ...
- 双元素非递增(容斥)--Number Of Permutations Educational Codeforces Round 71 (Rated for Div. 2)
题意:https://codeforc.es/contest/1207/problem/D n个元素,每个元素有a.b两个属性,问你n个元素的a序列和b序列有多少种排序方法使他们不同时非递减(不同时g ...
- CF D. Number Of Permutations 排列
挺水的一道题~ 拿全排列随便乘一下就好了. #include <cstdio> #include <algorithm> #define N 300004 #define ll ...
- 1207D Number Of Permutations
题目大意 给你n个二元组 问你有几种排列是的按两个关键字中的任意一个都不是不降排列的 分析 不妨容斥 我们先加上总的方案数$n!$ 之后我们按第一个关键字排序 因为值相同的情况下不影响答案 所以让总方 ...
- codeforces 341C Iahub and Permutations(组合数dp)
C. Iahub and Permutations time limit per test 1 second memory limit per test 256 megabytes input sta ...
- hdu 4055 Number String(dp)
Problem Description The signature of a permutation is a string that is computed as follows: for each ...
- codeforces 340E Iahub and Permutations(错排or容斥)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Iahub and Permutations Iahub is so happy ...
- hdu 4055 Number String(有点思维的DP)
Number String Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- hdu4055 Number String
Number String Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
随机推荐
- C# 不用添加WebService引用,调用WebService方法
// 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消注释以下行. [System.Web.Script.Services.ScriptService] 使用HttpWeb ...
- 03 Go语言特性
一.基本注意事项 1.转义字符 \t 一个制表符,代表一次tab \n 换行符 \\ 转义代表 \ \" 转义代表 " \r 一个回车,从当前行的最前面开始输出,会覆盖以前的内容, ...
- OO方式实现ALV: cl_salv_table
这里总结最近用cl_salv_table实现ALV遇到问题和解决办法 FORM set_alv2 . DATA: lv_syrepid TYPE syrepid. lv_syrepid = sy-cp ...
- ssh登录缓慢,使用ssh -v登录后,显示在 “pledge: network” 处卡顿:
当登录一台服务器时,每次输入密码之后都要等很久才会得到命令提示符,尝试修改了sshd_config中的UseDNS no,但效果依然不好. ssh -v 192.168.12.43 This is p ...
- Webmin代码执行漏洞复现
0x00 前言之前由于hw,没得时间分析.这个webmin相信大家很多次都在内网扫到过.也是内网拿机器得分的一环. 0x01影响版本Webmin<=1.920 0x02 环境搭建 建议大家以后用 ...
- fastadmin 随笔 刷新表格数据 获取当前登录人信息 服务端导出Excel
table.bootstrapTable('refresh',{url:'你的url'}); 获取当前登录人信息 $this->auth就能获取当前用户信息,比如$this->auth-& ...
- Odoo的 数据添加修改删除代码和对应的方式
完整的可用命令如下: (0, _ , {‘field’: value})新建一条记录并将其与之关联 (1, id, {‘field’: value})更新已关联记录的值 (2, id, _)移除关联并 ...
- Linux工具之top
top命令详解: 第一行:10:01:23----当前系统时间 126days,14:29------系统已经运行了126天14小时29分钟(在这期间没有重启过) 2users------当前 ...
- 7.Nginx_Keepalived高可用配置
2. 利用keepalived实现高可靠配置(HA) 2.1. 高可靠概念 HA(High Available):高可用性集群,是保证业务连续性的有效解决方案,一般有两个或两个以上的节点,且分为活动节 ...
- 5.Nginx的session一致性(共享)问题配置方案1
1:Session共享 为什么要实现共享,如果你的网站是存放在一个机器上,那么会话数据就在这台机器,但是如果你使用了负载均衡把请求分发到不同的机器呢?这个时候会话 id在客户端是没有问题的,但是如果用 ...