写在前面

众所周知,在 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的码风的更多相关文章

  1. $Yeasion$的码风修改历程

    总之,今天是一个值得纪念的伟大日子,我将自己的码风进行了彻底的修改,大概是参考了Pks和\(Rqy\)的码风,分为以下几点. 1.变量名.在所有的计算符号之前和之后加空格.如:"&& ...

  2. P1106 删数问题 自己码风好菜

    一个人的码风好坏究竟会影响多少

  3. $\mathcal{Miemeng}$的病态码风计划

    晚上困的要命,先写个码风计划提提神. 计划目标 抵制无理压行. 抵制不可读代码. 倡导代码艺术化,分层化 具体的一些细节和展示 1>整体 首先要把预读部分(我这么叫的),命名域使用,全局变量定义 ...

  4. 码风QwQ

    注:卡常.压行时怎么有效怎么来QwQ 快读真香.( 不喜欢用字符数组,使用string. 此时cin cout输入前会加这样三句以优化: ios::sync_with_stdio(0); cin.ti ...

  5. 【BZOJ 2152】聪聪可可 点分治

    对于一棵树,fdrt找到重心,然后分治每个子树. 在一棵以重心为根的树上,符合条件的链是: 1.过重心(根) 2.不过重心 对于1我们只需dfs出距离重心(根)的距离然后统计再减去有重叠的边 对于2我 ...

  6. 【BZOJ-1009】GT考试 KMP+DP+矩阵乘法+快速幂

    1009: [HNOI2008]GT考试 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 2745  Solved: 1694[Submit][Statu ...

  7. BZOJ 4547: Hdu5171 小奇的集合

    Sol 首先,考虑这个要怎么搞...让总和最大的方法就是选出当前集合中最大的两个数相加放入集合中就可以了,证明非常简单,当前集合的和为x,它的和只会一直往后增加,所以只需要找到最大的两个数的和加入便是 ...

  8. 最大流加强 dinic+当前弧优化

    qyy开始练习网络流啦 , 啊 ,蒟蒻只会套版 ,很裸的题 , 我连题都不想发了 ,可以参考我的代码(虽然我也是看的别人的 #include <iostream> #include < ...

  9. 2015 Multi-University Training Contest 4

    1001 Olympiad 签到题1. # include <iostream> # include <cstdio> using namespace std; ]={}; b ...

随机推荐

  1. Excel:11个查询函数组合

    还不懂?上栗子~ 1.普通查找 根据表二中的姓名,查找表一对应的应发工资.最基础的VLOOKUP函数就能搞定. 2.反向查找 根据表二姓名,查找表一编号.但表一中编号列在姓名列之前,无法直接使用VLO ...

  2. Linux系统centos6.7上安装libevent

    1 下载地址:http://libevent.org/ 2.解压 tar zxvf libevent-2.0.21-stable.tar.gz 安装前请先安装 gcc yum install gcc ...

  3. Hadoop基础-MapReduce入门篇之编写简单的Wordcount测试代码

    Hadoop基础-MapReduce入门篇之编写简单的Wordcount测试代码 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本文主要是记录一写我在学习MapReduce时的一些 ...

  4. 全角的空格(A1A1)惹的祸!

    #先上干货 “A1A1”是指全角的空格(GBK码): #验证 由上图可以看出半角的空格的HEX为"20": 由上图可以看出,在ANSI格式编码的文件中输入的全角的空格,转换为HEX ...

  5. android studio导出apk

    在android studio导出的apk分为4种,一种是未签名调试版apk,一种是未签名发行版apk,一种是已签名调试版apk,还有一种是已签名发行版apk.以下将介绍这4种apk如何导出. 一.调 ...

  6. 细说java之编码

    JAVA编程中涉及的编码 1.J2EE中涉及的编码(1) HttpServletResponse响应内容编码: resp.setCharacterEncoding(charset); (2)JSP文件 ...

  7. node 中 安装 yarn

    Yarn是Facebook最近发布的一款依赖包安装工具.Yarn是一个新的快速安全可信赖的可以替代NPM的依赖管理工具 快速安装 //在NPM 中安装npm install -g yarn MacOS ...

  8. Java入门系列 Lambda表达式

    https://blog.csdn.net/bitcarmanlee/article/details/70195403

  9. luogu 1268 树的重量

    打眼一看就是最小生成树嘛,但经过板子wa掉的经历后得知,,emmmm,原来是, 构造! (虽然不知是什么但觉得听起来很厉害的样子...手动微笑) n=2的情况 自然就是g(1,2) n=3的情况,由于 ...

  10. 【核心】project(idea文件)、module(iml文件)到SSM集成、热部署、Tomcat启动、MAVEN依赖冲突

    http://wiki.jikexueyuan.com/project/intellij-idea-tutorial/project-composition-introduce.html 在 Inte ...