chenfy27的刷题记录

导航

2024年10月20日 #

abc044C Tak and Cards

摘要: 有N张卡片,第i张卡片上的数字为x[i],可以从中选择1张或多张卡片,要求平均数为A,求方案数。 1<=N<=50; 1<=A<=50; 1<=x[i]<=50 分析:由于N最大为50,dfs搜索会超时,考虑dp。记dp[i][j][k]表示前i张卡片中选择了j张,并且和为k,根据每张卡片选与不选进 阅读全文

posted @ 2024-10-20 22:47 chenfy27 阅读(14) 评论(0) 推荐(0)

abc248E K-colinear Line

摘要: 给定二维平面上的N个不同的点,坐标分别为(X[i],Y[i]),问存在多少条直线穿过至少K个点? 1<=K<=N<=300;|X[i]|,|Y[i]|<=1E9 分析:最多只有300个点,可以枚举所有点对构成的直线,用斜率和截距表示,为了避免精度问题,两者用分数来表示。注意,平行与x轴和y轴的直线要 阅读全文

posted @ 2024-10-20 18:59 chenfy27 阅读(16) 评论(0) 推荐(0)

abc358E Alphabet Tiles

摘要: 现有大写英文字母A-Z,个数分别为C[i],总共可以组成多少个长度在[1,K]之间的不同串?答案对998244353取模。 1<=K<=1000, 0<=C[i]<=1000 分析:记dp[i][k]表示前i类字母构成长度为k的不同方案数,枚举第i类字母的个数j进行转移。 #include <bit 阅读全文

posted @ 2024-10-20 17:37 chenfy27 阅读(18) 评论(0) 推荐(0)

abc376E Max x Sum

摘要: 有序列A[N]和B[N],选出一组大小为K的下标,让A[i]的最大值乘以(B[i]之和)的结果最小,求最小值。 1<=T<=2E5, 1<=K<=N<=2E5, 1<=A[i],B[i]<=1E6 分析:因为A[i]跟B[i]要同步选,因此对下标排序,然后枚举每个A[i]作为最大值,从B[i]中选出 阅读全文

posted @ 2024-10-20 14:05 chenfy27 阅读(11) 评论(0) 推荐(0)

abc376D Cycle

摘要: 有N个顶点M条边的简单有向图,求包含1号点的最小环的顶点数,如果不存在,输出-1。 2<=N<=2E5, 1<=M<=2E5 分析:bfs求最小环。 #include <bits/stdc++.h> using i64 = long long; void solve() { int N, M; st 阅读全文

posted @ 2024-10-20 13:59 chenfy27 阅读(20) 评论(0) 推荐(0)

abc376C Prepare Another Box

摘要: 有N个玩具,大小分别为A[i];另外有N-1个盒子,大小分别为B[i]。现要再买一个盒子,把所有玩具装到盒子里,要求每个玩具都装一个盒子,并且玩具大小不超过盒子大小。问买的盒子至少为多大?如果无法满足,输出-1。 2<=N<=2E5, 1<=A[i],B[i]<=1E9 分析:将玩具按从大到小排序再 阅读全文

posted @ 2024-10-20 13:56 chenfy27 阅读(66) 评论(0) 推荐(0)

abc376B Hands on Ring (Easy)

摘要: 由1~N的块构成的环,最初左手在1号、右手在2号,接下来有Q组操作{H, T},H可以是L或者R,分别表示左手和右手,T是目标位置,移动时要求左右手不能在同一个块上。 3<=N<=100, 1<=Q<=100 分析:模拟,关键在于如何判断是顺时针移动还是逆时针移动。 #include <bits/s 阅读全文

posted @ 2024-10-20 13:48 chenfy27 阅读(93) 评论(0) 推荐(0)