1.换行的秘诀
大部分菜鸟接触到C++用的换行都是endl,但是endl太慢!。"\n"比endl快很多倍,举个例子大家就知道了。
endl
#include<bits/stdc++.h>
using namespace std;
int main()
{
for(int i=1;i<=5000;i++)
{
cout<<i<<endl;
}
return 0;
}
"\n"
#include<bits/stdc++.h>
using namespace std;
int main()
{
for(int i=1;i<=5000;i++)
{
cout<<i<<"\n";
}
return 0;
}
可以看到,endl是比"\n"慢很多的,但是大部分人觉得打"\n"太麻烦,不习惯。在此透露一种方法
#define endl "\n"
#include<bits/stdc++.h>
#define endl "\n"
using namespace std;
int main()
{
for(int i=1;i<=5000;i++)
{
cout<<i<<endl;
}
return 0;
}
这样就跟"\n"一样快啦!
2.输入输出的秘诀
有人说上面的输入输出还不够快,送上第二秘诀:
#include<bits/stdc++.h>
#define endl "\n"
using namespace std;
int main()
{
/*!前方高能!*/
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
for(int i=1;i<=5000;i++)
{
cout<<i<<endl;
}
return 0;
}
可以看见,快了十倍!
注意:此段代码不可与printf,scanf混用!
3.数组与下标可以互换
正常的数组
#include<bits/stdc++.h>
#define endl "\n"
using namespace std;
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int num[10];
for(int i=0;i<10;i++)num[i]=i;
for(int i=0;i<10;i++)cout<<num[i]<<" ";
return 0;
}
颠倒的数组
#include<bits/stdc++.h>
#define endl "\n"
using namespace std;
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int num[10];
for(int i=0;i<10;i++)i[num]=i;//编译成功了!
for(int i=0;i<10;i++)cout<<i[num]<<" ";//成功了!!
return 0;
}
好像还比num[i]更快!