引言

众所周知,打算法竞赛最频繁使用的语言是 C++。然而,对于那些不卡复杂度的题目,可以考虑使用 Python 编写(因为 Python 真的好写)。

本文将简单地介绍一些 Python 使用技巧和语法糖。

一些技巧

框架

初学 Python 时,由于 Python 著名的交互性,大家可能会直接逐行编写 Python 语句。然而,这样便于代码逻辑组织和函数的编写。如同 C++ 中的 int main() { ... } 一样,Python 中也可以构建类似的程序框架。

def foo():
print("Hello") def main():
foo() if __name__ == '__main__':
main()

最后一句的意义为:

  • 当执行本文件时,正常运行 main() 函数;
  • 当从外部调用文件时,可以导入本文件中编写的函数,而不执行 main() 函数。

这样,保证了编写的代码既可以执行,又可以外部调用。

全局变量

Python 中的全局变量需要在函数中用 global 命令声明后才能进行修改,例子如下。

x = 0

def foo():
x += 10 def bar():
global x
x += 10 def main():
foo()
bar()

调用 foo() 会抛出 UnboundLocalError: local variable 'x' referenced before assignment

具体原因参看 Python中的global关键字,你了解吗

重定向输入输出

如同 C++ 中的 freopen() 函数,Python 中也有将标准 I/O 重定向到文件的命令。

import sys
sys.stdin = open(r'hack.txt', 'r')
sys.stdout = open(r'hack.out', 'w')

这样就可以把样例放到 hack.txt 中,输出到 hack.out 中了。

_debug_

Python 中有一个内置常量 __debug__,其默认值为 True。当编译命令中开启 -O 时,其值为 False

我用这个技巧来替代 C++ 中的 #if(n)def ... #else ... #endif 语句(不同于 C/C++,Python 没有预编译过程,故也没有完全对应的命令)。

默认 OJ 是不会开启 -O 命令的(不过还是在提交前查看 OJ 对应的语言编译命令说明为好),所以我们可以定义一个常量

LOCAL = not __debug__ # True if compile option '-O'

这样我们在本地运行开启 -O 命令之后,就可以使用

if LOCAL:
print("Hello")

来指定本地编写时执行但 OJ 不执行的命令。

例如将上一节的重定向可以加上这句,就不用担心由于忘记注释掉重定向而收获一发 RE 了

断言

Python 的断言关键字与 C++ 相同,都是 assert;在抛出 AssertionError 时可以指定报错信息。例子如下:

a, b = 1, 2
assert a == b, f'{a} != {b}'

终端会抛出 AssertionError: 1 != 2

随机数生成器与对拍

随机数生成

例如生成 A+B problem 的随机数据。生成的数据直接输出到 hack.txt 中。

import sys
from random import * # seed(12345)
sys.stdout = open(r'hack.txt', 'w') n = int(1e3)
print(n)
for i in range(n):
a = randint(-1e9, 1e9)
b = randint(-1e9, 1e9)
print(a, b)

对拍

检验两个程序是否有相同输出,构造样例和 debug 时常用。

不一定是两个 *.exe,只要是有输入输出的东西都可以拍。

from os import system

while True:
system("python3 randgen.py")
system("true.exe < ../hack.txt > true.txt")
system("false.exe < ../hack.txt > false.txt")
if system("fc true.txt false.txt"):
system("pause")

更进阶的用法,考虑使用 洛谷推出的对拍工具 CYaRon,使用 pip 直接安装即可。

代码运行计时

使用标准库中的 time 模块

import time

if __name__ == '__main__':
T1 = time.time()
main()
T2 = time.time()
print("Runtime: %.3f s." % (T2 - T1), file=sys.stderr)

print() 的 kwg 中指定 file=sys.stderr 使得运行时间在终端输出。这样当重定向输入输出时,该语句不受影响。

不过通常来讲,选择使用 Python 编写时,基本都是对运行时间要求不高的题目。

模板

贴上自用的 Python 模板

#!/usr/bin/python3
import sys
import os
import time
from functools import reduce
from math import * LOCAL = not __debug__ # True if compile option '-O' def main():
pass if __name__ == "__main__":
T1 = time.time()
if LOCAL:
sys.stdin = open(r"hack.txt", "r")
sys.stdout = open(r"hack.out", "w")
t = int(input()) # 1
for i in range(t):
print(f"Case #{i+1}:", end=' ')
main()
T2 = time.time()
print("Runtime: %.3f s." % (T2 - T1), file=sys.stderr)

我的赛前模板仓库

git clone git@github.com:RivTian/Python-Content.git

参考

  1. Python 3 官方文档 - 中文 https://docs.python.org/zh-cn/3/
  2. Python 中的 global 关键字,你了解吗?https://zhuanlan.zhihu.com/p/111284408

使用 Python 参与算法竞赛的更多相关文章

  1. 如何使用Python在Kaggle竞赛中成为Top15

    如何使用Python在Kaggle竞赛中成为Top15 Kaggle比赛是一个学习数据科学和投资时间的非常的方式,我自己通过Kaggle学习到了很多数据科学的概念和思想,在我学习编程之后的几个月就开始 ...

  2. 浅谈Python在信息学竞赛中的运用及Python的基本用法

    浅谈Python在信息学竞赛中的运用及Python的基本用法 前言 众所周知,Python是一种非常实用的语言.但是由于其运算时的低效和解释型编译,在信息学竞赛中并不用于完成算法程序.但正如LRJ在& ...

  3. Hihocoder 太阁最新面经算法竞赛18

    Hihocoder 太阁最新面经算法竞赛18 source: https://hihocoder.com/contest/hihointerview27/problems 题目1 : Big Plus ...

  4. hihoCoder太阁最新面经算法竞赛15

    hihoCoder太阁最新面经算法竞赛15 Link: http://hihocoder.com/contest/hihointerview24 题目1 : Boarding Passes 时间限制: ...

  5. Python基础算法综合:加减乘除四则运算方法

    #!usr/bin/env python# -*- coding:utf-8 -*-#python的算法加减乘除用符号:+,-,*,/来表示#以下全是python2.x写法,3.x以上请在python ...

  6. (Step1-500题)UVaOJ+算法竞赛入门经典+挑战编程+USACO

    http://www.cnblogs.com/sxiszero/p/3618737.html 下面给出的题目共计560道,去掉重复的也有近500题,作为ACMer Training Step1,用1年 ...

  7. xsank的快餐 » Python simhash算法解决字符串相似问题

    xsank的快餐 » Python simhash算法解决字符串相似问题 Python simhash算法解决字符串相似问题

  8. [刷题]算法竞赛入门经典 3-12/UVa11809

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-4/UVa11809:Floating-Point Numbers 代码: //UVa11 ...

  9. [刷题]算法竞赛入门经典 3-10/UVa1587 3-11/UVa1588

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-10/UVa1587:Box 代码: //UVa1587 - Box #include&l ...

  10. [刷题]算法竞赛入门经典 3-7/UVa1368 3-8/UVa202 3-9/UVa10340

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 都是<算法竞赛入门经典(第二版)>的题目,标题上没写(第二版) 题目:算法竞赛入门经典 3-7/UVa13 ...

随机推荐

  1. 提升效率,打通万里牛ERP与下游用友U8财务软件的无缝对接

    一.对接流程 1.1 销售/售后流程 在万里牛订单出库后,通过轻易云数据集成平台将数据推送至用友U8销售订单和销售出库单,这些单据可以进行关联操作. 当万里牛售后单完成退货入库后,通过数据集成平台将数 ...

  2. 我用 AI 写的《JavaScript 工程师的 Python 指南》电子书发布啦!

    关于本书 你好,我是 luckrnx09,一名靠 React 恰饭的前端工程师,很高兴向你介绍我的第一本开源电子书<JavaScript 工程师的 Python 指南>. 本书的内容完全免 ...

  3. hello Flask最简单的Flask项目

    # 1.导包 from flask import Flask # 2.实例化Flask对象.一般变量名都叫app,大家都是这样用,很多扩展插件的文档也是叫app,所以统一都叫app. # __name ...

  4. 反向 Debug 了解一下?揭秘 Java DEBUG 的基本原理

    Debug 的时候,都遇到过手速太快,直接跳过了自己想调试的方法.代码的时候吧-- 一旦跳过,可能就得重新执行一遍,准备数据.重新启动可能几分钟就过去了. 好在IDE 们都很强大,还给你后悔的机会,可 ...

  5. 华企盾DSC远程桌面、实时监控连接不上常见处理方法

    1.检测策略是否勾选了远程桌面需要客户端确认或者勾选了客户端显示"允许远程维护"选项 2.检查客户端5097目录是否有MgrDll.dll.uvnserver.exe文件(是否被杀 ...

  6. 【UniApp】-uni-app-打包成小程序

    前言 大家好,我是 BNTang, 在上一节文章中,我给大家详细的介绍了如何将我开发好的项目打包为网页. 趁热打铁,在来一篇文章,给大家详细的介绍如何将项目打包为小程序. 正文 打开微信小程序呢,其实 ...

  7. VSCode 中优雅地编写 Markdown

    VSCode 中优雅地编写 Markdown 在 VSCode 中编写 Markdown 有几个无法拒绝的优势,首先是顺手方便,常写代码的同学打开 VSCode 各项功能和快捷键使用的都比较熟练,可以 ...

  8. 部署堡垒机5——安装Core

    部署jumpserver服务核心组件Core 一.前期准备 一个后台程序,基本上都是需要依赖于数据库才能运行,后台程序在启动的时候,代码就回去连接数据库,保证数据库,正确启动,且可以正确连接,否则后台 ...

  9. Linux发行版的基础目录名称、命名法则及功能规定

    罗列Linux发行版的基础目录名称命名法则及功用规定 目录描述 /主层次 的根,也是整个文件系统层次结构的根目录 /bin存放在单用户模式可用的必要命令二进制文件,所有用户都可用,如 cat.ls.c ...

  10. ZincSearch轻量级全文搜索引擎入门到

    ZincSearch轻量级全文搜索引擎入门到 Zinc是一个用于对文档进行全文搜索的搜索引擎.它是开源的,内置在 Go 中.Zinc不是从头开始构建索引引擎,而是构建在 bluge 之上,这是一个出色 ...