COMP9021 Principles of Programming WEEK6 Optional

1. About exam

exam建议先通读题目,找到适合自己的做题排序,优先做自己容易解决的。
考试环境是IDE,需要做的事情是:打开考试文件,coding,submit,会有写好的doctest,如果运行没有结果出现,千万别忘记这说明你做对了。

2. Nash equilibrium

Lecture5的尾巴,在博弈中的非合作模式达到的平衡。
"The Nash equilibrium is a solution concept of a non-cooperative game involving two or more players in which each player is assumed to know the equilibrium strategies of the other players, and no player has anything to gain by changing only his own strategy."
这个部分没有演示coding,详细内容在PDF文档中。

3.Regular expression

re module引入用来查验regular expression:

import re
X = re.search('ab', 'abcabc')
print(X)
>>>
<_sre.SRE_Match object; span=(0, 2), match='ab'>
# span=(0, 2)代表位置0-2找到匹配对象,match='ab'代表找到的匹配对象

常用元字符:
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束

常用限定符:
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次

X = re.search('\w', '%123abcabc')
print(X)
>>>
<_sre.SRE_Match object; span=(1, 2), match='1'>
#\w寻找的是字母/数字/下划线/汉字,起始位置是%,不match,然后是1,match,返回找到的结果

X = re.search('\w*', '%asd%%dfg')
print(X)
>>> 
<_sre.SRE_Match object; span=(0, 0), match=''>
#‘*’重复任意次数,所以'\w*'允许空(重复0次),起始位置是%,不是\w,所以返回空

X = re.search('\w*', 'asd%%dfg')
print(X)
>>>
<_sre.SRE_Match object; span=(0, 3), match='asd'>
#与上面代码相比差,去掉了起始位置的%,这样寻找任意长度的字母,返回的是asd

X = re.search('\w+', '%asd%%dfg')
print(X)
>>>
<_sre.SRE_Match object; span=(1, 4), match='asd'>
#+表示至少出现一次,所以找到asd

X = re.search('0|[1-9]\d*', '04')
print(X)
>>>
<_sre.SRE_Match object; span=(0, 1), match='0'>
#|表示逻辑OR,'0|[1-9]\d*'表示数字0或者是非0的任意长度数字。所以返回第一位找到的数字0

X = re.search('^0|[1-9]\d*$', '04')
print(X)
>>>
<_sre.SRE_Match object; span=(0, 1), match='0'>
#'^0|[1-9]\d*$'表示以0或任意非0数字开头结尾的情况,所以返回第一位找到的数字0

X = re.search('(^0|[1-9]\d*)$', '04')
print(X)
>>>
<_sre.SRE_Match object; span=(1, 2), match='4'>
#()代表匹配,加入了括号后,含义改变,'(^0|[1-9]\d*)$'代表的是以0或者非0数字结尾的情况,所以返回结尾前面的数字4

4. Regular Expression Exercise

写出符合' ( +- 200 , +- 343 ) '形式的正则:

import re
X = re.search('^\s*\(\s*[+-]?([1-9]\d*)\s*,\s*[+-]?([1-9]\d*)\s*\)\s*$', '  ( 123, 45 )')
print(X)
>>> 
<_sre.SRE_Match object; span=(0, 13), match='  ( 123, 45 )'>
#[+-]?代表选择其中之一或没有符号,因为?含义是0个或1个
X.group()
>>>
('123', '45')
#显示找到的结果分类

#如果想要显示正负号,则需要用()capture,可是这样会产生多个括号,每一个括号都是一个capture对象,所以结果是4个
X = re.search('^\s*\(\s*([+-]?([1-9]\d*))\s*,\s*([+-]?([1-9]\d*))\s*\)\s*$', '  ( +123, -45 )')
X.groups()
>>>
('+123', '123', '-45', '45')

#如果想要不去capture某个括号内内容,使用(?: XXX)的方法
X = re.search('^\s*\(\s*([+-]?(?:[1-9]\d*))\s*,\s*([+-]?(?:[1-9]\d*))\s*\)\s*$', '  ( +123, -45 )')
X.groups()
>>>
('+123', '-45')

另一个练习关于(?: )

X = re.search('(a(bc))((d(ef))g)', 'abcdefg')
X.groups()
>>>
('abc', 'bc', 'defg', 'def', 'ef')

X = re.search('(a(bc))((?:d(ef))g)', 'abcdefg')
X.groups()
>>>
('abc', 'bc', 'defg', 'ef')
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,845评论 18 139
  • 念往昔风华正茂, 看今朝两鬓斑斑, 叹三十年时光之悠悠, 各自奔波为糊口, 今日再聚首, 执手相看泪眼, 竟晃如隔...
    缘wxh阅读 545评论 2 10
  • 又是一年考研时。先交代一下,目前我已经在国内某高校读研,研二,考研总分402分。 最近很多学...
    爱疯爱笑女神经阅读 1,250评论 12 56
  • 做计划时,很容易就钻进实际执行细节上去了,脑子不清楚 成年人的世界只有底线z善事;没有钱,就做点家务事;动得了,就...
    新家中男孩阅读 217评论 0 0