又臭又长的快读快写代码谁爱用谁用。正式比赛敲错模板有你爽的。
正常情况下使用下面这两行代码
ios::sync_with_stdio(false) #使用了该代码就不要使用scanf和printf。
cin.tie(nullptr) #遇到交互题请不要使用。忘记或误用 cin.tie(0) | orz-panda (xidian.wiki)
宏定义
#define endl '\n' #遇到交互题请不要使用。忘记或误用 cin.tie(0) | orz-panda (xidian.wiki)
模板
#include <bits/stdc++.h>
//#define int long long
#define per(i,j,k) for(int (i)=(j);(i)<=(k);++(i))
#define rep(i,j,k) for(int (i)=(j);(i)>=(k);--(i))
#define debug(a) cout<<#a<<"="<<a<<endl
#define fr first
#define se second
#define endl '\n'
using namespace std;
void solve(){
}
signed main(){
ios::sync_with_stdio(false),cin.tie(nullptr);
int t=1;
cin>>t;
while(t--)solve();
return 0;
}
实际测试得出,全局变量可以使用的变量内存比局部变量大了10倍左右,但是在函数内使用内存,多次调用函数不会带来额外的内存消耗,如果不需要申请1e6以及更大的变量内存,只需要所有代码写在solve里面就行。
如果你发现你代码没问题,但是就是运行不了,提示报错,然后网上一查报错代码说栈溢出或者递归死循环了,可能就是内存在栈里放不下,数组没开出来提示的报错。这时就要把局部变量的数组放到全局里面。
多测的时候如果写全局变量,下次使用就需要初始化,只有solve不需要初始化。
所以只需要考虑是否用到很多内存,如果很多就去全局变量申请,或者只有一次输入,多次访问,智能选择如何创建。
如果没有多测,把cin>>t;注释掉即可。
debug不生效没输出的时候,需要把define endl '\n'注释掉,正常运行结束'\n'才会输出,如果中途死循环了,使用endl才会刷新缓冲区输出。
还有一个void函数的特殊用法,来自z01prime
void dfs(int x){
if(x>10){
ans++;
return ;
}
}
我们又想执行ans++,又想return,同一行效果如下
void dfs(int x){
if(x>10)return ans++,void();
//if(x>10)ans++,return;是非法的
}
逗号运算符返回后者的值,void即空。执行了ans++,同时也返回了空。
可以简单理解成返回ans++(实际上没有返回值)