NOIP考试技巧及注意事项&&信息学竞赛常用函数/模板

本文分享了NOIP提高组考试的技巧和注意事项,包括使用(a+1)而非(a++)等细节。同时,介绍了信息学竞赛中常用的函数和模板,如扩展欧几里得算法、乘法逆元、高精度模板等。此外,还提到了线性时间复杂度计算欧拉函数、BSGS算法、卢卡斯定理和扩展中国剩余定理等高级算法。并涉及数据结构如并查集、二叉堆、二维树状数组和Splay树的应用。最后,介绍了对拍器的制作和快速输入输出方法。
摘要由CSDN通过智能技术生成

函数中记得用(a+1),而不是(a++)


OI 中转站
OI算法大全


[NOIP提高组(2018)考试技巧及注意事项] (https://blog.csdn.net/hi_ker/article/details/81181615)

1.保持好的心态

2.审题

3.考虑严谨

4.代码正确

5.freopen

6.检查

还有注意检查你的程序是否在考试指定文件夹里面,而且不能存在指定文件夹的子文件夹里面

7.防爆(防止爆数组)

8.头文件

9.数据类型

10.增加程序的鲁棒性(Robust)

11.注意隐性错误(非常重要)


以下讨论主要是基于windows考试环境

1.时间复杂度的选择

2.利用Dev C++

3.对拍

4.巧用cmd(选学)

5.查错

6.骗分




[信息学竞赛常用函数/模板] (https://blog.csdn.net/Hi_KER/article/details/82973124)

  • 扩展欧几里得算法
void exgcd(int a,int b,int& d,int& x,int& y){
   
    if(!b){
   d=a,x=1,y=0;return;}
    exgcd(b,a%b,d,y,x);y-=x*(a/b);
}
  • 乘法逆元
void exgcd(int a,int b,int& d,int& x,int& y){
   
    if(!b){
   d=a,x=1,y=0;return;}
    exgcd(b,a%b,d,y,x);y-=x*(a/b);
}
int inverse(int a,int m){
   
	int x,y,d;
	exgcd(a,m,d,x,y);
	return d==1?(x%m+m)%m:-1;
}

  • 高精度模板

https://blog.csdn.net/Hi_KER/article/details/80982710

  • O ( N ) O(\sqrt {N}) ON )计算欧拉函数
int phi(int x){
   
	int ans=x,m=sqrt(x+0.01);
	for(int i=2;i<=m;i++) if(x%i==0){
   
		ans=ans/i*(i-1);
		while(x%i==0) x/=i;
	}
	if(x>1) ans=ans/x*(x-1);//x为质数
	return ans;
}

  • 线性时间复杂度生成欧拉函数表+质数表
/* 
p|n &&  p*p|n phi(n)=phi(n/p)*p
p|n && !p*p|n phi(n)=phi(n/p)*(p-1) 
*/ 
int v[maxn],pri[maxn],phi[maxn];
void eular(int n){
   
	int num=0;//number of prime 
	for(int i=2;i<=n;i++) {
   
		if(v[i]==0){
   //v[i]:i 的最小质因子
			v[i]=i,pri[++num]=i;
			phi[i]=i-1;
		}
		for(int j=1;j<=num;j++){
   
			if(pri[j]>v[i]||pri[j]>n/i) break;
			v[i*pri[j]]=pri[j];
			phi[i*pri[j]]=phi[i]*(i%pri[j]?pri[j]-1:pri[j]);
		}
	}
	for(int i=1;i<=n;i++) printf("phi(%d)=%d\n",i,phi[i]);
}

  • BSGS算法(说明:用于计算高次同余方程 a x ≡ b   ( m o d   p ) a ^ x \equiv b\ (mod\ p) axb (mod p) 的最小非负数解,其中 p p p为素数,时间复杂度 O ( P ) O(\sqrt{P} ) O(P ),返回 − 1 -1 1表示无解)
int pow_mod(int a,int n,int p){
   
	int ret=1;
	while(n){
   
		if(n&1) ret=(long long)ret*a%p;
		a=(long long)a*a%p,n>>=1;
	}
	return ret;
}
map<int,int>mp;
int bsgs(int a,int b,int p){
   
	if(a%p==0) return b?-1:0;
	mp.clear();
	int m=ceil(sqrt(p)),T=b%p;
	mp[T]=0;
	for(int i=1;i<=m;i++)
		mp[T=(long long)T*a%p]=i;
	int t=pow_mod(a,m,p);T=1;
	for(int i=1;i<=m;i++){
   
		T=(long long)T*t%p;
		if(mp.count(T)) return i*m-mp[T];
	}
	return -1;
}

  • 卢卡斯(Lucas)定理
int C(int N,int M,int p){
   
    if(N<M) return 0;
    if(!n) return 1;
    return (ll)fac
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值