type
status
date
slug
summary
tags
category
icon
password
Property
Jul 13, 2023 01:59 PM
Sequences & Data Abstraction
data:image/s3,"s3://crabby-images/7b64f/7b64f00d848365c416e054dfc845d4ab82730e2b" alt="notion image"
Sequences
data:image/s3,"s3://crabby-images/56108/5610844d14d1cb0490f12dfe034675727f40f2ba" alt="notion image"
data:image/s3,"s3://crabby-images/5fa15/5fa15b5847081591344cf3ac71388cbfa024c6a3" alt="notion image"
List是任何值类型的一个序列
Sequence Abstraction
data:image/s3,"s3://crabby-images/ea2e0/ea2e0aac2cc7492a669291909033bc22e8413a91" alt="notion image"
[a:b]可以从字符串中街区一个部分,索引从a开始,截取到索引b-1(包括b-1)
可以设置间隔进行跳过
可以进行加法
data:image/s3,"s3://crabby-images/f18c5/f18c53e88977ae6337d093893ff0efcadb4baa7f" alt="notion image"
Sequence Processing
data:image/s3,"s3://crabby-images/58b07/58b0718dd5f0c47f01d65119d551fd941931f37d" alt="notion image"
可以使用while循环进行遍历
data:image/s3,"s3://crabby-images/beaad/beaad436d08c96f4d07e1ececccd2963c6b0fb6e" alt="notion image"
data:image/s3,"s3://crabby-images/68b48/68b4844976f008052e012d85f47fca361bc38c37" alt="notion image"
for循环和while是等价的
读取超出索引范围值的时候会报错
Range
data:image/s3,"s3://crabby-images/7881f/7881f54ae14661dc9eb824ef5dccf03c3b48712c" alt="notion image"
一样的是包前不包后,可以每隔多少个跳过
List Comprehensions
data:image/s3,"s3://crabby-images/76b51/76b51326054f9b152f1d5af244c85d8bca5bab4c" alt="notion image"
这种表达式并不会影响局部变量
Examples
data:image/s3,"s3://crabby-images/f2827/f2827cd6a0c1110bde2e1304aadb5387c8aaf42c" alt="notion image"
Data Abstraction
data:image/s3,"s3://crabby-images/d76f1/d76f1a6ba3941e2a7cc63e9e6a820843b47d6bbc" alt="notion image"
data:image/s3,"s3://crabby-images/d12ea/d12ea1760a0ee551f9e316f601db3a9ba0667206" alt="notion image"
data:image/s3,"s3://crabby-images/203bc/203bcc43a145ec68b735f04ac672474a3be76231" alt="notion image"
Rational Numbers Arithmetic
data:image/s3,"s3://crabby-images/7233f/7233fa9ef2b2050c5931346be6c21e3c887b1aa9" alt="notion image"
data:image/s3,"s3://crabby-images/da6fd/da6fd007fc28446f47c53447895e61b53a1a97bb" alt="notion image"
利用selector取出分子和分母,然后做运算
data:image/s3,"s3://crabby-images/38fae/38fae4fef9229709b67f4b107e2dc326d51dc9b2" alt="notion image"
data:image/s3,"s3://crabby-images/dd4e7/dd4e778c3d178885e3e310908d5b859b588e510e" alt="notion image"
Representing Rational Numbers
data:image/s3,"s3://crabby-images/f01fb/f01fba89eecf031749533ae3b603dda18ebe7e1d" alt="notion image"
还需要有一些辅助函数
执行结果
Reducing to Lowest Terms
data:image/s3,"s3://crabby-images/a3bff/a3bff9063f707dec5052fe0cf66d111723da4276" alt="notion image"
引入gcd 最大公约数
Abstraction Barriers
data:image/s3,"s3://crabby-images/b364d/b364d936cc1b9afecaf47a6eb3c062f833883e50" alt="notion image"
Violating Abstraction Barriers
data:image/s3,"s3://crabby-images/88aaa/88aaa586d6453c5ff1cd0a485e2775e2d9b0a7e9" alt="notion image"
这样是违反了抽象,因为没有传入rational构造函数。
因为你不敢保证你函数内部的实现就是一个Array,也许是其他的实现方式。只不过在这个地方是这样实现的。
一种别的实现方式
Dict Data
上面的函数也可以使用dict来实现,而不是数组
- 作者:Kitety
- 链接:https://www.kitety.com/article/cs-61a-8
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。
相关文章