c++加速方法大全

我们平常写代码的时候,经常超时,非常难受,所以,我写了这篇文章,让你的代码提升速度(这些方法作者亲测有效,用了这些方法,足足提升了1秒!虽然最后题目还是没过)

1、读入、输出加速:

cpp 复制代码
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);

这三行代码可以提升我们cin和cout的读入和输出速度,具体原理我也不太懂,反正你也不用知道,会用就行了

但是我们要注意,就算我们用了这三行代码,cin和cout的读入输出速度还是没有printf和scanf快,所以想要加速的更快,就要用printf和scanf

这里还有一种加速方法,叫快读快写,似乎比printf更快(我也不知道是不是真的)

cpp 复制代码
inline int read(){//快读
    int x=0,w=0;
    char ch=0;
    while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
    while(isdigit(ch)){x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
    return w ? -x : x;
}
inline void write(int x){//快写
    if(x<0)putchar('-'),x=-x;
    if(x>9)write(x/10);putchar(x%10+'0');
}

原理嘛,多看几遍大概都能看懂,主要是怎么用

快读这么用:

cpp 复制代码
int x;//要读入x
x=read();//x=read读入的值

快写这么用:

cpp 复制代码
int x=5;//要输出x
write(x);//输出x

注意,快读不能读入字符,只能读入数字(读入字符一点反应也没有);快写不能写字符,只能输出数字

快读快写还用升级版:

cpp 复制代码
namespace IO{
int len = 0;
char ibuf[(1<<20)+1],*iS,*iT,out[(1<<25)+1];
#define gh()    \
    (iS==iT?iT=(iS=ibuf)+fread(ibuf,1,(1<<20)+1,stdin),    \
    (iS==iT?EOF:*iS++):*iS++)
#define reg register
inline int read(){
	reg char ch=gh();
	reg int x=0;
	reg char t=0;
	while(ch<'0'||ch>'9')
		t|=ch=='-',ch=gh();
	while(ch>='0'&&ch<='9')
		x=x*10+(ch^48),ch=gh();
	return t ? -x : x;
}
inline void putc(char ch){
	out[len++]=ch;
}
template <class T> inline void write(T x){
	if (x < 0)
		putc('-'),x=-x;
	if (x > 9)
		write(x/10);
out[len++]=x%10+48;
}
inline void flush(){
	fwrite(out,1,len,stdout);
	len=0;
}
}
using IO::flush;
using IO::putc;
using IO::read;
using IO::write;

虽然我知道这是升级版,但我不会用╥﹏╥

2、O3优化:

cpp 复制代码
#pragma GCC optimize(2)

写代码的时候,把这句写进去(写在头文件下面),就能加速了,这是O2优化,那什么是O3优化呢?

cpp 复制代码
#pragma GCC optimize(3)

这就是O3优化,把2改成3就好了,很简单吧?而且O3确实比O2快(亲测有效)


好了,这就是我知道的所有加速方法了,当然还是有一些小细节的东西,比如在循环内定义变量合在循环外定义变量有什么区别,这些我就不太懂了,你们可以找别的问文章

相关推荐
REDcker1 天前
有限状态机与状态模式详解 FSM建模Java状态模式与C++表驱动模板实践
java·c++·状态模式
basketball6161 天前
C++ 构造函数完全指南:从入门到进阶
java·开发语言·c++
想唱rap1 天前
IO多路转接之poll
服务器·开发语言·数据库·c++
落羽的落羽1 天前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
goodesocket1 天前
芯片HAST测试:通电工作下如何精准模拟极端环境挑战?
c++
特种加菲猫1 天前
从零开始手撕AVL树:详解插入、平衡因子更新与四种旋转
开发语言·c++
萑澈1 天前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
江屿风1 天前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法
运筹vivo@1 天前
LeetCode 2405. 子字符串的最优划分
c++·算法·leetcode·职场和发展·哈希表
有点。1 天前
C++(枚举法一练习题)
开发语言·c++·算法