xht37的码风
写在前面
众所周知,在 Dev-C++ 上有一个代码格式化的功能,快捷键Ctrl+Shift+A
我的码风致力于写出格式化后毫无变化的代码,这被认为是标准代码
同时,对不可格式化的部分(如空格),我同样也会详细说明
值得一提的是,我的码风是跟着 lydrainbowcat 学的,在此致谢
头文件
一般情况下使用万能头文件,即:
#include <bits/stdc++.h>
注意 include 后有空格
不使用万能头文件的情况:
在 POJ 等不能使用万能头文件的
落后OJ上提交写 std
这种情况下,不同的头文件按照长度为第一关键字,字典序为第二关键字从上至下依序排列,如:
#include <cmath>
#include <cstdio>
#include <vector>
#include <cstring>
#include <iostream>
#include <algorithm>
原则上不必要的头文件不写
宏定义 & const
宏定义用于简写出现多次的较长字符串,如:
#define ll long long
#define pii pair<int, int>
或利用宏定义简写整条语句,如:
#define For (i, l, r) for (int i = l; i <= r; i++)
#define get(x) (t[t[x].f].ch[1] == x)
const 用于且只用于定义常量,如;
const int N = 1e5 + 6;
const double eps = 1e-6;
注意,const 如果由于定义表示数组大小的常量,则:
其中代表常量的字符必须大写
数必须为 xey + 6 的形式,其中 x, y 为具体的数
using namespace std;
紧跟在待 # 号的语句后面写,待 # 号的语句包括:
- 头文件
#include <...>
- 宏定义
#define ... ...
快读
平时禁止使用,比赛/考试时视情况而定
模板:
inline int rd() {
int x = 0, o = 1;
char ch = getchar();
for (; !isdigit(ch); ch = getchar())
if (ch == '-') o = -1;
for (; isdigit(ch); ch = getchar())
x = x * 10 + ch - '0';
return x * o;
}
空格
下列情况使用空格:
逗号,分号之后
for, while, if 之后
任何运算符号的前后
大括号不换行,在大括号之前
结构体定义完后直接声明变量,在反大括号之后
下列情况禁止使用空格,若与上面矛盾以禁止为优先:
[] 内一个空格都不能有
( 的右边,) 的左边
++, -- 与变量之间
空行
用于且只用于下列情况:
所有全局变量定义在开头,全部定义完之后
两个函数之间
主函数之后
inline
非递归函数时必须使用,递归函数时禁止使用
register
禁止使用别问我为什么
typedef
禁止使用别问我为什么
逗号
用于一次声明多个同类型变量,如:
int x, y;
可以适当利用逗号压行,如:
x = q.top(), q.pop();
ios::sync_with_stdio(0)
一般情况下禁止使用,但在使用 string 时例外,注意使用后不能用 scanf, printf
输入
少量输入使用 cin,大量输入使用 scanf
输出
少量输出使用 cout,大量输出使用 printf
大括号
一条语句禁止打大括号,多条语句必须打大括号而定
自加,自减
循环时必须在变量之后,其他视具体情况而定
下标
推荐从 1 开始,但不禁止从 0 开始
位运算
能使用位运算代替就尽量使用毕竟位运算是真快,卡常效果显著,但不能影响程序的可读性
xht37的码风的更多相关文章
- $Yeasion$的码风修改历程
总之,今天是一个值得纪念的伟大日子,我将自己的码风进行了彻底的修改,大概是参考了Pks和\(Rqy\)的码风,分为以下几点. 1.变量名.在所有的计算符号之前和之后加空格.如:"&& ...
- P1106 删数问题 自己码风好菜
一个人的码风好坏究竟会影响多少
- $\mathcal{Miemeng}$的病态码风计划
晚上困的要命,先写个码风计划提提神. 计划目标 抵制无理压行. 抵制不可读代码. 倡导代码艺术化,分层化 具体的一些细节和展示 1>整体 首先要把预读部分(我这么叫的),命名域使用,全局变量定义 ...
- 码风QwQ
注:卡常.压行时怎么有效怎么来QwQ 快读真香.( 不喜欢用字符数组,使用string. 此时cin cout输入前会加这样三句以优化: ios::sync_with_stdio(0); cin.ti ...
- 【BZOJ 2152】聪聪可可 点分治
对于一棵树,fdrt找到重心,然后分治每个子树. 在一棵以重心为根的树上,符合条件的链是: 1.过重心(根) 2.不过重心 对于1我们只需dfs出距离重心(根)的距离然后统计再减去有重叠的边 对于2我 ...
- 【BZOJ-1009】GT考试 KMP+DP+矩阵乘法+快速幂
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2745 Solved: 1694[Submit][Statu ...
- BZOJ 4547: Hdu5171 小奇的集合
Sol 首先,考虑这个要怎么搞...让总和最大的方法就是选出当前集合中最大的两个数相加放入集合中就可以了,证明非常简单,当前集合的和为x,它的和只会一直往后增加,所以只需要找到最大的两个数的和加入便是 ...
- 最大流加强 dinic+当前弧优化
qyy开始练习网络流啦 , 啊 ,蒟蒻只会套版 ,很裸的题 , 我连题都不想发了 ,可以参考我的代码(虽然我也是看的别人的 #include <iostream> #include < ...
- 2015 Multi-University Training Contest 4
1001 Olympiad 签到题1. # include <iostream> # include <cstdio> using namespace std; ]={}; b ...
随机推荐
- Prometheus+AlertManager实现邮件报警
AlertManager下载 https://prometheus.io/download/ 解压 添加配置文件test.yml,配置收发邮件邮箱 参考配置: global: smtp_smartho ...
- Journal Storage Directory not formatted
类型一: 当你从异常信息中看到JournalNode not formatted,如果在异常中看到三个节点都提示需要格式化JournalNode. 如果你是新建集群,你可以重新格式化NameNode, ...
- 解决pycharm问题:module 'pip' has no attribute 'main'
问题 更新pip之后,Pycharm安装package出现如下报错: 解决 找到安装目录下 helpers/packaging_tool.py文件,找到如下代码: 修改为如下,保存即可.
- Hadoop记录-hdfs转载
Hadoop 存档 每个文件均按块存储,每个块的元数据存储在namenode的内存中,因此hadoop存储小文件会非常低效.因为大量的小文件会耗尽namenode中的大部分内存.但注意,存储小文件所需 ...
- Web API中的模型验证
一.模型验证的作用 在ASP.NET Web API中,我们可以使用 System.ComponentModel.DataAnnotations 命名空间中的属性为模型上的属性设置验证规则. 一个模型 ...
- ubuntu linux下建立stm32开发环境: 程序烧录 openocd+openjtag
原文出处: http://blog.csdn.net/embbnux/article/details/17619621 之前建立stm32开发环境,程序也已经编译好生成main.bin,接下来就是要把 ...
- rpmbuild打包php
安装php依赖库 mkdir -pv ~/rpmbuild/{BUILD,RPMS,SOURCES,SPECS,SRPMS} php有一个依赖库,在yum源于epel源中都没有需要自己打包libico ...
- 在Java中如何高效的判断数组中是否包含某个元素
原文出处: hollischuang(@Hollis_Chuang) 如何检查一个数组(无序)是否包含一个特定的值?这是一个在Java中经常用到的并且非常有用的操作.同时,这个问题在Stack Ove ...
- HDU - 1255 覆盖的面积 (线段树求面积交)
https://cn.vjudge.net/problem/HDU-1255 题意 给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 分析 求面积并的题:https://www.cnbl ...
- es6之箭头函数
=> 箭头函数是ES6增加的函数表达式.将function关键字和函数名都删掉,并使用“=>”连接参数列表和函数体(低版本浏览器不支持) 箭头函数看上去只是语法的变动,其实也影响了this ...