[2021.4.7多校省选模拟33]A,B,C

文章目录

  • 考试复盘
  • A
  • B
  • C

考试复盘

今天的题其实蛮温柔的

考完试预估分160160160,好家伙到手的只有14\frac{1}{4}41

第一题是原题,做过的,虽然忘记怎么做了。。。⊙︿⊙

但是因为本身较简单,考场上也想到了正解

但是因为我的SBSBSB二分midmidmid附近点的取舍可能导致了答案位置的偏差111

(╥╯^╰╥)哭晕在厕所了谢谢

第二题感觉就是DPDPDP转移,联想到了正睿的一道划段合并DPDPDP

但是passpasspass了,发现自己需要将i,i+1i,i+1i,i+1i,i−1i,i-1i,i1是否相邻的信息拿到

自己的DPDPDP转移不动

反正就是没想到再拿一个DPDPDP,两个相互转移

打了303030的暴力表,结果又出现了经典菜谱——没输入完就直接return0return\ 0return 0

丢了

第三题扑脸而来的NTTNTTNTT味道,但是不会

只能写最原始的DPDPDP暴力打表,结果忘记调用打表函数,结果全是000

Y(>_<、)Y

总结:

今天考试的题目比较简单,所以暴露出了很多细节/策略问题,如果在省选场上出现那简直就是死亡名单

1.对细节偏差非常讲究的题目(T1)一定要构造数据想办法测一测那个临界附近

2.如果暴力分能打表,那么最好先写了后放在后面自己跑,继续往下做。今天是最后十几分钟打的表,时间就很紧张。如果一开始看到就直接打表肯定是不会这么慌张的(T3)

3.对于自己不喜欢写对拍这件事,真的要在后面每一场比赛中强迫自己写——不一定要拍正解,至少保证自己能拿到的分一定不能丢!(T2如果写对拍,肯定发现自己直接结束程序的bug)

省选在即,把握细节,优化策略,是最后的王牌!

A

考虑枚举作为中位数的妹子

然后两边一定是选一段等长的区间

设选的中位数在mid处

二分两边选多少数,设选了x个

比较这2x+12x+12x+1个数的平均数和第mid−xmid-xmidxn−x+1n-x+1nx+1个数的平均数

如果前者大,说明xxx应该变小,否则xxx变大

#include <cmath>
#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
#define maxn 200005
int n;
double a[maxn], sum[maxn];double calc( int pos, int x ) {return ( sum[pos] - sum[pos - x - 1] + sum[n] - sum[n - x] ) / ( x << 1 | 1 );
}int main() {scanf( "%d", &n );for( int i = 1;i <= n;i ++ )scanf( "%lf", &a[i] );sort( a + 1, a + n + 1 );for( int i = 1;i <= n;i ++ )sum[i] = sum[i - 1] + a[i];double ret = 0;for( int i = 1;i <= n;i ++ ) {int l = 0, r = min( i - 1, n - i ), x = 0;while( l < r ) {int mid = ( l + r ) >> 1;if( calc( i, mid ) < calc( i, mid + 1 ) )l = mid + 1;elser = mid;}ret = max( ret, calc( i, l ) - a[i] );}printf( "%.4f\n", ret );return 0;
}

B

设计状态f[i][j]f[i][j]f[i][j]表示前iii个数的排列且包含jjj对非法相邻数对的方案数,当我们放入i+1i+1i+1这个数的时候发生3种状况:

  • 打破一对非法相邻数对

  • 增加一对非法相邻数对

  • 不变。

增加的情况就发生在iiii+1i+1i+1相邻的情况

所以我们还需要知道iii是否处于某个非法相邻数对。

因此重新设计状态

f[i][j]f[i][j]f[i][j]:前i个数的排列且包含j对非法相邻数对,iii存在于非法相邻数对中的方案数

g[i][j]g[i][j]g[i][j]iii不存在于非法相邻数对中的方案数

转移就是考虑i+1i+1i+1的放置方法

f[i][j]f[i][j]f[i][j] 的放置方法有4种:

  • 与i相邻且增加一对非法相邻数对,只会是[i−1,i,i+1],1[i-1,i,i+1], 1[i1,i,i+1],1种方法

    f[i+1][j+1]f[i+1][j+1]f[i+1][j+1]

  • iii相邻且不改变非法相邻数对数,只会是[i−1,i+1,i],1[i-1,i+1,i], 1[i1,i+1,i],1种方法

    f[i+1][j]f[i+1][j]f[i+1][j]

  • 不与iii相邻且减少一对非法相邻数对,有j−1j-1j1种方法

    g[i+1][j−1]g[i+1][j-1]g[i+1][j1]

  • 不与i相邻且不改变非法相邻数对数,有i−ji-jij种方法

    g[i+1][j]g[i+1][j]g[i+1][j]

g[i][j]g[i][j]g[i][j]333种情况

  • iii相邻且增加一对非法相邻数对,可能是[i+1,i][i+1,i][i+1,i][i,i+1],2[i,i+1],2[i,i+1]2种方法

    f[i+1][j+1]f[i+1][j+1]f[i+1][j+1]

  • 不与iii相邻且减少一对非法相邻数对,有jjj种摆放方法

    g[i+1][j−1]g[i+1][j-1]g[i+1][j1]

  • 不与iii相邻且不改变非法相邻数对数,有i−j−1i-j-1ij1种摆放方法

    g[i+1][j]g[i+1][j]g[i+1][j]

最终的答案就是g[N][0]g[N][0]g[N][0]

#include <cstdio>
#include <cstring>
#define int long long
#define maxn 1005
int n, mod;
int f[maxn][maxn], g[maxn][maxn];signed main() {while( ~ scanf( "%lld %lld", &n, &mod ) ) {memset( f, 0, sizeof( f ) );memset( g, 0, sizeof( g ) );g[1][0] = 1;for( int i = 1;i < n;i ++ )for( int j = 0;j < i;j ++ ) {f[i + 1][j + 1] = ( f[i + 1][j + 1] + f[i][j] ) % mod;f[i + 1][j] = ( f[i + 1][j] + f[i][j] ) % mod;if( j ) g[i + 1][j - 1] = ( g[i + 1][j - 1] + f[i][j] * ( j - 1 ) ) % mod;g[i + 1][j] = ( g[i + 1][j] + f[i][j] * ( i - j ) ) % mod;f[i + 1][j + 1] = ( f[i + 1][j + 1] + g[i][j] * 2 ) % mod;if( j ) g[i + 1][j - 1] = ( g[i + 1][j - 1] + g[i][j] * j ) % mod;g[i + 1][j] = ( g[i + 1][j] + g[i][j] * ( i - j - 1 ) ) % mod; }printf( "%lld\n", ( g[n][0] + mod ) % mod );}return 0;
}

C

N=3×7×11×47=10857N=3\times 7\times 11\times 47 =10857N=3×7×11×47=10857

fi,jf_{i,j}fi,j表示前iii位模NNNjjj的方案数

利用倍增思想,优化暴力转移

f2i,(j⋅10i+k)%N=∑fi,j⋅fi,kf_{2i,(j·10^i+k)\%N}=\sum f_{i,j}·f_{i,k}f2i,(j10i+k)%N=fi,jfi,k

固定2i2i2i,令k=10i,gt=∑j⋅k%N=tfi,j,ht=fi,tk=10^i,g_t=\sum_{j·k\%N=t}f_{i,j},h_t=f_{i,t}k=10i,gt=jk%N=tfi,j,ht=fi,t

则转移变为f2i,j+k=gj∗hkf_{2i,j+k}=g_j*h_kf2i,j+k=gjhk

标准可爱的卷积形式,FFTFFTFFT加速矩阵

#include <cmath>
#include <cstdio>
#include <iostream>
using namespace std;
#define ll long long
#define maxn 200100
#define mod 9973
#define N 10857struct complex {double x, i;complex(){}complex( double X, double I ) {x = X, i = I;}
}A[maxn], B[maxn];double pi = acos( -1.0 );complex operator + ( complex a, complex b ) {return complex( a.x + b.x, a.i + b.i );
}complex operator - ( complex a, complex b ) {return complex( a.x - b.x, a.i - b.i );
}complex operator * ( complex a, complex b ) {return complex( a.x * b.x - a.i * b.i, a.x * b.i + a.i * b.x );
}int len = 32768;
int r[maxn];void FFT( complex *v, int opt ) {for( int i = 0;i < len;i ++ )if( i < r[i] ) swap( v[i], v[r[i]] );for( int i = 1;i < len;i <<= 1 ) {complex omega( cos( pi / i ), opt * sin( pi / i ) );for( int j = 0;j < len;j += ( i << 1 ) ) {complex w( 1, 0 );for( int k = 0;k < i;k ++, w = w * omega ) {complex x = v[j + k], y = v[j + k + i] * w;v[j + k] = x + y;v[j + k + i] = x - y;}}}
}int qkpow( int x, int y ) {int ans = 1;while( y ) {if( y & 1 ) ans = ans * x % N;x = x * x % N;y >>= 1;}return ans;
}bool check( int x ) {return x % 2 && x % 3 && x % 5 && x % 7 && x % 11 && x % 47;
}void mul( int *f, int *g, int L ) {int k = qkpow( 10, L );for( int i = 0;i < N;i ++ ) {A[i * k % N] = complex( int( f[i] + A[i * k % N].x ) % mod , 0 );B[i] = complex( g[i], 0 );f[i] = 0;}FFT( A, 1 ), FFT( B, 1 );for( int i = 0;i < len;i ++ ) A[i] = A[i] * B[i];FFT( A, -1 );for( int i = 0;i < len;i ++ ) {f[i % N] = ( f[i % N] + (ll)( A[i].x / len + 0.5 ) ) % mod;A[i] = B[i] = complex( 0, 0 );}
}int n;
int c[5] = { 1, 2, 3, 5, 7 };
int f[maxn], g[maxn];int main() {scanf( "%d", &n );if( n == 1 ) return ! printf( "1\n" );else n --;int L = f[0] = g[1] = g[2] = g[3] = g[5] = g[7] = 1;int l = log2( len );for( int i = 0;i < len;i ++ )r[i] = ( r[i >> 1] >> 1 ) | ( ( i & 1 ) << ( l - 1 ) );while( n ) {if( n & 1 ) mul( f, g, L );mul( g, g, L );n >>= 1;L <<= 1;}int ans = 0;for( int i = 0;i < N;i ++ )for( int j = 0;j < 5;j ++ )if( check( i * 10 + c[j] ) )ans = ( ans + f[i] ) % mod;else;printf( "%d\n", ans );return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317471.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 8 新提案让泛型 Attribute 成为现实

从一开始&#xff0c; Attribute 就是.NET 的一部分。因此&#xff0c;它们在引入泛型之前就已经被创建好&#xff0c;这意味着如果要引用属性中的类型&#xff0c;必须暴露一个 Type 参数或属性。例如&#xff1a;[TypeConverter(typeof(X))]这种模式存在一些限制。在上面的示…

P5044-[IOI2018] meetings 会议【dp,笛卡尔树,线段树二分】

正题 题目链接:https://www.luogu.com.cn/problem/P5044 题目大意 给出一个长度为nnn的序列hhh&#xff0c;定义dis(x,y)max{hi}(x≤i≤y)dis(x,y)max\{h_i\}(x\leq i\leq y)dis(x,y)max{hi​}(x≤i≤y)。 qqq次询问给出一个区间[L,R][L,R][L,R]&#xff0c;找到一个x∈[L,R]…

模板:线段树标记永久化

为了那不可知的询问永远坚守于此 解析 众所周知线段树的区间修改是需要打懒标记的 多数时候&#xff0c;这个标记在询问子区间时需要下传 而标记永久化&#xff0c;就是指不下传懒标记的一种操作 在某些时候标记不便下传时有所应用 比如zkw线段树和二维线段树等 然而zkw线段树…

1305. GT考试

1305. GT考试 题意&#xff1a; 准考证长度为n位&#xff0c;不吉利数字有m位&#xff0c;问不出现不吉利数字的准考证有多少种&#xff0c;答案mod K 题解&#xff1a; 动态规划kmp矩阵快速幂 设dp[i][j]表示长度为i&#xff0c;且不包含S串&#xff0c;且末尾部分与S串的…

.NET Core IdentityServer4实战 第二章-OpenID Connect添加用户认证

内容&#xff1a;本文带大家使用IdentityServer4进行使用OpenID Connect添加用户认证作者&#xff1a;zara(张子浩) 欢迎分享&#xff0c;但需在文章鲜明处留下原文地址。在这一篇文章中我们希望使用OpenID Connect这种方式来验证我们的MVC程序&#xff08;需要有IdentityServe…

[CF/AT]各大网站网赛 体验部部长第一季度工作报告

文章目录CodeForces#712 (Div. 1)——1503A. Balance the BitsB. 3-ColoringC. Travelling Salesman ProblemD. Flip the Cards108 (Rated for Div. 2)——1519A. Red and Blue BeansB. The Cake Is a LieC. Berland RegionalD. Maximum Sum of ProductsE. Off by OneCodeforce…

G - Tiling FZU - 2040(未解决)

G - Tiling FZU - 2040 题意&#xff1a; m * n的矩阵&#xff0c;通过任意大小的矩阵&#xff0c;有多少种填充方式&#xff1f; 图片为3 * 2的矩阵有如下填充方式&#xff1a; 题解&#xff1a; 矩阵快速幂 目前还没参透 代码:

P7520-[省选联考 2021 A 卷]支配

正题 题目链接:https://www.luogu.com.cn/problem/P7520 题目大意 给出nnn个点mmm条边的一张有向图&#xff0c;一号点为起始点&#xff0c;qqq次独立的询问加入一条边后有多少个点的支配集发生了变化。 1≤n≤3000,1≤m≤2n,1≤q≤21041\leq n\leq 3000,1\leq m\leq 2\times…

11.16 模拟:总结

220pts 100100020 整体还可以&#xff0c;虽然T3挂掉了&#xff0c;但T1T2做出来还是不错的 问题&#xff1a; 开局审错了题&#xff01;T2调了太久T3写挂了白给了40… &#xff08;我临交前就觉得T3细节这么多很可能挂还检查了一遍&#xff09; 只能说我的直觉很灵敏了 这…

C# 8 的新提案:new 关键字类型推断

在很多情况下&#xff0c;一个地方只允许出现一种可能的类型。C# 仍然要求你明确列出类型&#xff0c;但如果目标类型“new”表达式提案被采用&#xff0c;那么就不再需要这些样板代码。从表面上看&#xff0c;这个特性看起来与 var 关键字恰好相反。它不是根据表达式推断出变量…

CF1540B Tree Array(期望,dp)

解析 关于合理的实现 这题卡在最后的小破dp是我没想到的 一开始看到200的数据范围就不禁笑出了声 lca直接On求&#xff01; 然后就开始大力分类讨论 然后就卡在了一个问题上 两个栈AB&#xff0c;分别有a和b个元素&#xff0c;随机从两个栈中弹出一个元素&#xff0c;求最后A栈…

pjudge#21614-[PR #1]守卫【Kruskal生成树,费用流】

正题 题目链接:http://pjudge.ac/problem/21614 题目大意 给出一张nnn个点mmm条边的一张图&#xff0c;有kkk个守卫&#xff0c;每个守卫都有一个点集SSS表示这个守卫可以被派遣到这个点集中的某个点&#xff0c;然后你可以选择一些边删除&#xff0c;要求使得每个点都恰好和…

I - The Mad Mathematician FZU - 2042(未解决)

I - The Mad Mathematician FZU - 2042 题意&#xff1a; 给你一段伪代码&#xff1a;如图 现在给你A&#xff0c;B&#xff0c;C&#xff0c;D&#xff0c;E&#xff0c;的具体值&#xff0c;问你sum是多少 0<A,B,C,D,E<263-1 题解&#xff1a; 数位dp&#xff1f;…

程序员修仙之路--高性能排序多个文件

点击上方蓝色字体&#xff0c;关注我们菜菜呀&#xff0c;昨天晚上班级空间崩溃了程序员主力 Y总what&#xff1f;菜菜我看服务器上写了很多个日志文件&#xff0c;我看着太费劲了&#xff0c;能不能按照日期排序整合成一个文件呀&#xff1f;程序员主力 Y总Y总要查日志呀&…

CF718E Matvey‘s Birthday(状压、bfs、暴力、分类讨论)

解析 比较复杂的一道题 看数据范围&#xff0c;我们肯定要从种类很少的颜色入手 因为第二种加边方式和颜色密切相关 所以设计disi,kdis_{i,k}disi,k​表示 i 号节点到颜色为 k 的节点的最小步数 通过对每个k bfs一遍就能得出答案 然后两个点之间的距离就可以写出转移式&#…

P5366-[SNOI2017]遗失的答案【状压dp,FWT】

正题 题目链接:https://www.luogu.com.cn/problem/P5366 题目大意 给出一个n,G,Ln,G,Ln,G,L。 qqq次询问在1∼n1\sim n1∼n中选择若干个数字并且数字xxx必选&#xff0c;要求这些数的gcdgcdgcd为GGG且lcmlcmlcm为LLL的方案数。 1≤n,G,L,x≤108,1≤q≤1051\leq n,G,L,x\leq 1…

2017ACM/ICPC广西邀请赛

2017ACM/ICPC广西邀请赛&#xff08;感谢广西大学&#xff09; 题号题目考点难度AA Math Problem数论签到题BColor itCCounting StarsDCoveringECS Course思维 &#xff0c;二进制思维题FDestroy Walls最大生成树GDuizi and Shunzi思维题HLaw of CommutationIMatching in a Tr…

【.NET Core项目实战-统一认证平台】第十四章 授权篇-自定义授权方式

上篇文章我介绍了如何强制令牌过期的实现&#xff0c;相信大家对IdentityServer4的验证流程有了更深的了解&#xff0c;本篇我将介绍如何使用自定义的授权方式集成老的业务系统验证&#xff0c;然后根据不同的客户端使用不同的认证方式来集成到统一认证平台。.netcore项目实战交…

CF1500C Matrix Sorting(拓扑排序)

解析 神仙题 我想到了一部分&#xff0c;但是由于没想到倒着做&#xff0c;后面越想越复杂… 本题的关键是要倒着想 考虑最后一次排序的列x 必须是单调不增的 否则直接错 然后倒数第二列y 必须在x列相等的段内单调不增&#xff0c;因为这些地方x无法起到排序的作用 同理再到倒…

P8292-[省选联考 2022]卡牌【状压,容斥】

正题 题目链接:https://www.luogu.com.cn/problem/P8292 题目大意 有nnn张卡牌&#xff0c;第iii张上的数字是sis_isi​。mmm次询问给出cic_ici​个质数&#xff0c;要求选择一些卡使得这些卡的乘积是这些质数的倍数&#xff0c;求方案数。 1≤n≤106,1≤si≤2000,1≤m≤1500…