多校联测11 THUSC

这篇具有很好参考价值的文章主要介绍了多校联测11 THUSC。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目大意

n n n个人参加 T H U S C THUSC THUSC,第 i i i个人算法场和工程场的成绩分别为 a i a_i ai b i b_i bi,保证不存在两个人两项成绩都相同。

现在招办想给他们排个名。一个合理的排名方案是分别给算法场和工程场一个正的权重 x , y x,y x,y,然后按照 a i x + b i y a_ix+b_iy aix+biy降序排名,相同的可以按照他们的心情排。

对于一个成绩分布,求有多少种可能的排名。

输出答案对 998244353 998244353 998244353取模后的值。

1 ≤ n ≤ 1000 , 1 ≤ a i , b i ≤ 1 0 9 1\leq n\leq 1000,1\leq a_i,b_i\leq 10^9 1n1000,1ai,bi109


题解

因为当 x 1 ≠ x 2 , y 1 ≠ y 2 x_1\neq x_2,y_1\neq y_2 x1=x2,y1=y2 x 1 y 1 = x 2 y 2 \dfrac{x_1}{y_1}=\dfrac{x_2}{y_2} y1x1=y2x2时,权重为 x 1 , y 1 x_1,y_1 x1,y1 x 2 , y 2 x_2,y_2 x2,y2所得的排名是相同的。所以,我们只需考虑比值 x y \dfrac xy yx,令比值为 w = x y w=\dfrac xy w=yx

首先,我们把所有满足题意的 w w w分成两个类型:

  • 能使有至少两个人分数一样
  • 能使任意两个人的分数不一样

因为存在分数一样的时候分数相同的任意排,所以所有第二种类型的 w w w所得的排名都一定会在第一种类型的 w w w所得的排名中出现。(可以自己举几个例子试一下)。

那么,我们只需要求能使至少两个人分数一样的 w w w即可,而能使至少两个人分数一样的 w w w不超过 n 2 n^2 n2个(对于任意两对 a i , b i a_i,b_i ai,bi,只有一个 w w w满足两者排名相同)。

枚举两个人 i , j i,j i,j,求出能使 i , j i,j i,j两个人分数相等的 w w w。然后,我们只需考虑在每个不同的 w w w作为比值的情况下有多少种排名即可。

这怎么处理呢?我们在求出能使 i , j i,j i,j两个人分数相等的 w w w的时候,在图上将 i , j i,j i,j两点连一条权值为 w w w的双向边,再从虚拟节点 n + 1 n+1 n+1 i i i连一条权值为 w w w的单向边。等到全部边都连完了之后,对于每一个不同的 w w w,看虚拟节点有多少个权值为 w w w的边连出去。对于每个从虚拟节点指向的点 i i i,看从 i i i经过权值为 w w w的边能够到达多少个点(包括自己),这些点当前的分数是与 i i i的分数相同的。若能够到达 t t t个点,则贡献为 t ! t! t!。换句话说,设 v w v_w vw表示比值为 w w w时不同排名的数量,则当得知 i i i能到达 t t t个点时, v w = v w × t ! v_w=v_w\times t! vw=vw×t!

在处理边的时候,我们可以将每个点连出的边按边权从小到大排序,那么走过的边就不用再走了,能保证每条边只会被遍历一次。

因为相邻的两个能使两人分数相等的 w w w之间的那种排名会被计算两次,所以要减去,那么答案为 1 + ∑ ( v w − 1 ) 1+\sum (v_w-1) 1+(vw1)

枚举 i , j i,j i,j的时间复杂度为 O ( n 2 ) O(n^2) O(n2),排序的时间复杂度为 O ( n 2 log ⁡ n ) O(n^2\log n) O(n2logn)。总共有不超过 3 n 2 3n^2 3n2条边,每条边最多遍历一次,所以图上部分的时间复杂度为 O ( n 2 ) O(n^2) O(n2)。所以,总时间复杂度为 O ( n 2 log ⁡ n ) O(n^2\log n) O(n2logn)文章来源地址https://www.toymoban.com/news/detail-727921.html

code

#include<bits/stdc++.h>
using namespace std;
const long long mod=998244353;
const int N=3000000;
int n,w1=0,now,z[N+5],to[1005];
long long ans=0,nd,a[1005],b[1005],jc[1005];
struct node{
	int a,b;
	long long x,y;
	bool operator==(const node ax)const{
		return x==ax.x&&y==ax.y;
	}
	bool operator!=(const node ax)const{
		return x!=ax.x||y!=ax.y;
	}
}w[1000005];
struct pr{
	int x,v;
};
vector<pr>g[1005];
bool cmp(node ax,node bx){
	if(ax.x!=bx.x) return ax.x<bx.x;
	return ax.y<bx.y;
}
long long gcd(long long i,long long j){
	while(j){
		i%=j;swap(i,j);
	}
	return i;
}
void dfs(int u,int t){
	if(z[u]==t) return;
	z[u]=t;
	++now;
	for(int i=to[u];i<g[u].size();++i,++to[u]){
		if(w[g[u][i].v]!=w[t]) break;
		dfs(g[u][i].x,t);
	}
}
int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++){
		scanf("%lld%lld",&a[i],&b[i]);
	}
	jc[0]=1;
	for(int i=1;i<=1000;i++) jc[i]=jc[i-1]*i%mod;
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			long long x=b[i]-b[j],y=a[j]-a[i],d;
			if(x*y<0) continue;
			if(x==0||y==0) continue;
			if(x<0){
				x=-x;y=-y;
			}
			d=gcd(x,y);
			x/=d;y/=d;
			w[++w1]=(node){i,j,x,y};
		}
	}
	sort(w+1,w+w1+1,cmp);
	for(int i=1;i<=w1;i++){
		g[w[i].a].push_back((pr){w[i].b,i});
		g[w[i].b].push_back((pr){w[i].a,i});
		g[n+1].push_back((pr){w[i].a,i});
	}
	for(int i=1;i<=w1;i++){
		if(i>1&&w[i]==w[i-1]) continue;
		nd=1;
		for(int j=to[n+1];j<g[n+1].size();++j,++to[n+1]){
			if(w[g[n+1][j].v]!=w[i]) break;
			now=0;
			dfs(g[n+1][j].x,i);
			nd=nd*jc[now]%mod;
		}
		ans=(ans+nd)%mod;
		ans=(ans-1+mod)%mod;
	}
	ans=(ans+1)%mod;
	printf("%lld",ans);
	return 0;
}

到了这里,关于多校联测11 THUSC的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 2020第11届蓝桥杯矩阵的真·详细题解

    本文章主要面向算法初学者、蓝桥杯参赛者。 今天重温一手第十三届的统计子矩阵,搜索的时候发现了第十一届的矩阵题,然后看了下网上的文章,好家伙! 全网对于此题没有高质量的文章和解答思路,全是贴个代码最多说一两句别的话,代码里注释都没几行,对于初学者

    2023年04月16日
    浏览(41)
  • 【LeetCode】数据结构题解(11)[用队列实现栈]

    所属专栏:玩转数据结构题型❤️ 🚀 博主首页:初阳785❤️ 🚀 代码托管:chuyang785❤️ 🚀 感谢大家的支持,您的点赞和关注是对我最大的支持!!!❤️ 🚀 博主也会更加的努力,创作出更优质的博文!!❤️ 🚀 关注我,关注我,关注我,重要的事情说三遍!!!!!

    2024年02月13日
    浏览(39)
  • NOIP2023模拟9联测30-金牌

    link 记 d u d_u d u ​ 表示 u u u 到 1 1 1 的距离。 预处理出 s u m u = ∑ v ∈ T u 2 d v − d u sum_u=sumlimits_{vin T_{u}}2^{d_v-d_u} s u m u ​ = v ∈ T u ​ ∑ ​ 2 d v ​ − d u ​ 。 考虑两种情况 x x x 和 y y y 都不是 l c a lca l c a 。答案就是 2 dis ⁡ ( x , y ) ∑ u ∈ T x 2 d u − d x ∑ v ∈ T y 2 d v

    2024年02月06日
    浏览(36)
  • NOIP2023模拟7联测28 异或

    给定一个长度为 n n n 的由非负整数组成的序列 a a a ,你们需要进行一系列操作,每次操作选择一个区间 [ l , r ] [l,r] [ l , r ] ,对于所有 l ≤ i ≤ r lleq ileq r l ≤ i ≤ r ,将 a i a_i a i ​ 异或上 w w w 。你需要将所有 a i a_i a i ​ 都变为 0 0 0 ,求最小的操作次数。 1 ≤ n ≤ 17

    2024年02月06日
    浏览(39)
  • 2023NOIP A层联测18-划分

    题目 字符串编号从 1 1 1 开始。 若 n = k n=k n = k ,最大值很好求,方案数就是 1 1 1 。 若前 k k k 个都没有 1 1 1 ,设第一个 1 1 1 出现的位置为 m m m ,最大值是选 m m m 开始的后缀,划分方案是在前 m m m 个空位插大于等于 k − 1 k-1 k − 1 个隔板,用组合数可以轻松求出。 否则,

    2024年02月08日
    浏览(35)
  • NOIP2023模拟7联测28 花之舞

    有一个花园,每朵花可以表示为平面直角坐标系上的 N N N 个点,第 i i i 个点的坐标为 O ( x i , y i ) O(x_i,y_i) O ( x i ​ , y i ​ ) 。定义两朵花之间的距离为它们的切比雪夫距离,即 d i s ( u , v ) = max ⁡ ( ∣ x u − x v ∣ , ∣ y u − y v ∣ ) dis(u,v)=max(|x_u-x_v|,|y_u-y_v|) d i s ( u , v ) =

    2024年02月06日
    浏览(39)
  • [USACO11MAR] Brownie Slicing G题解(二分+二维前缀和+矩阵分割)

    题目地址 P3017 [USACO11MAR] Brownie Slicing G 二分最大化最小值 切割思路: 一行一行进行切割,如果这一行可以切割出b块大于等于mid的块,就开始切割下一行 如果无法切割出b块,就把正在切割的行与下一行拼起来一起切割 最后通过能切割出b块的水平块块够不够a条来判断m是否合

    2024年02月07日
    浏览(39)
  • CSP模拟58联测20 回忆旅途的过往

    题目大意 有 n n n 个砝码,每个砝码的初始重量为 a i a_i a i ​ 。有 q q q 次操作,每次操作分为以下两种类型: 1 l r x :表示将 l l l 到 r r r 之间的所有 a i a_i a i ​ 都变成 x x x 2 l r x :查询 l l l 到 r r r 之间的所有砝码,每个砝码可以用无限次,求是否能称出质量 x x x a i a_

    2024年02月07日
    浏览(46)
  • 20231112多校模拟T2

    给你下列7种形状,问恰好填满 (n*2) 的方格有多少种方案(每种形状可任意旋转) 后三种形状纯粹是出题人的恶趣味, d用没有 不会 定义: f[i] 为填满 (i*2) 的方格的方案数 g[i] 为填满 (i*2) 的方格 不能被腰斩 的方案数 解释:例如当 (n = 4) 时,下列第一种画法能被腰斩

    2024年02月05日
    浏览(26)
  • 6-101 LinkList11-求两个单链表的差集【有题解视频,可本地编译器调试】

    已知两个单链表A与B,设计算法AdiffB( ),构造出A与B的差集新链表C,链表C中的元素值为A链表中有而B链表中无的元素值。 要求C表的链点为新开辟的链点,不采用A、B链表中原有链点,最后要求遍历A、B、C三个链表。 数据结构定义 带头结点的单链表结点定义如下: typedef int

    2024年01月23日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包