刚来到清北学堂,收获颇多,首先是李昊大佬的一个有用的模板
#include<iostream> #include<algorithm> #include<cstdio> #include<cstring> #include<cmath> #include<cstdlib> using namespace std;//一堆头文件 typedef long long ll; typedef long double ld; typedef pair<int,int> pr; const double pi=acos(-1); #define rep(i,a,n) for(int i=a;i<=n;i++) #define per(i,n,a) for(int i=n;i>=a;i--)//一群for循环 #define Rep(i,u) for(int i=head[u];i;i=Next[i]) #define clr(a) memset(a,0,sizeof a) #define pb push_back #define mp make_pair #define fi first #define sc second ld eps=1e-9; ll pp=1000000007; ll mo(ll a,ll pp){if(a>=0 && a<pp)return a;a%=pp;if(a<0)a+=pp;return a;}//模运算优化 ll powmod(ll a,ll b,ll pp){ll ans=1;for(;b;b>>=1,a=mo(a*a,pp))if(b&1)ans=mo(ans*a,pp);return ans;}//快速幂 ll read(){ ll ans=0; char last=' ',ch=getchar(); while(ch<'0' || ch>'9')last=ch,ch=getchar(); while(ch>='0' && ch<='9')ans=ans*10+ch-'0',ch=getchar(); if(last=='-')ans=-ans; return ans; }//快读 //head//防止找不到从哪里开始...
这个主要是对于很多常用的语句和数据进行一下简化,在写程序的时候能够大幅提高速度,但是有两个不好的地方,主要是刚开始用的时候会不熟悉,而且自造代码的话不一定能够覆盖所有情况,所以就我而言我决定只是学会定义数据的方法比如define等,还有一个很重要的事情就是快读的优化,这个好的技巧在NOip考试是要用到的,所以要熟练掌握。