欢迎各位大佬评价码风
HighPerformanceRobot
2019-01-01 18:13:36
# 欢迎各位大佬莅临本蒟蒻的blog
进入正题。
### 正题
1.头文件中间不加空格,虽然我知道这看上去不大美观。
2.main函数里面几乎没有定义变量,i和j都是在循环中定义的。
3.用Dev-C++ 5.11的我特别喜欢"格式化->风格->Allman",所以for循环的三个表达式中间一般要有一个空格(当然,是格式化的时候自动加的)。
4.绝对没有空行!空行都被删了!全局变量要按类型和长度排序,极其厌恶乱七八糟的定义。
5.当for循环里面只有一个表达式的时候,我会坚决去掉那对大括号。
6.当if等语句里面的表达式过少时,我一般会用逗号连接它们(除非有continue/break/return之类的不能连起来的语句),以去掉那对大括号。
7.定义STL时,我都会在"STL种类"与"类型"之间加一个空格,在"类型"与"STL名称"之间加一个空格(主要是priority_queue的定义时遗留下的习惯)。
8.对cin/cout很严格,必须把关联关掉。
#### 范例
```cpp
#include<bits/stdc++.h>
#define INF 214748647
#define MAX_V 100S
using namespace std;
int n,m;
int x,y,z;
struct edge
{
int to,cost;
};
typedef pair < int,int > P;
vector <edge> G[MAX_V];
int d[MAX_V];
void dijkstra(int s)
{
priority_queue < P,vector<P>,greater<P> > que;
fill(d+1,d+n+1,INF);
d[s]=1;
que.push(P(1,s));
while(!que.empty())
{
P p=que.top();
que.pop();
int v=p.second;
if(d[v]<p.first)
continue;
for(int i=0; i<G[v].size(); i++)
{
edge e=G[v][i];
if(d[e.to]>d[v]*e.cost)
{
d[e.to]=d[v]*e.cost;
que.push(P(d[e.to],e.to));
}
}
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cin>>n>>m;
for(int j=1; j<=m; j++)
{
cin>>x>>y>>z;
edge now;
now.to=y,now.cost=z;
G[x].push_back(now);
}
dijkstra(1);
cout<<d[n]<<endl;
return 0;
}
```
有什么想法没有?欢迎在评论区留言评价。