欢迎各位大佬评价码风

HighPerformanceRobot

2019-01-01 18:13:36

Personal

# 欢迎各位大佬莅临本蒟蒻的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; } ``` 有什么想法没有?欢迎在评论区留言评价。