Haskell学习笔记--List Comprehension / Data.Char / 凯撒加密问题

List comprehension

序列内涵??恕我英语垃圾翻译不出来

但是它是一种应用在序列上的函数,写起来就像集合一样

相当于是用旧序列生成新序列,不妨翻译为序列生成

比如

[x^2 | x <- [1..10]]
--[1,4,9,16,25,36,49,64,81,100]

[(x,y) | x <- [1..3] , y <- [x..3] ]
--[(1,1),(1,2),(1,3),(2,2),(2,3),(3,3)]

 

有个函数 concat

用来把序列套序列的最外层去掉

concat :: [[a]] -> [a]
concat xss = [x | xs <- xss , x <- xs ]

 

Guard

其实就是加上限制条件

factor :: Int -> [Int]
factor n = [x | x <- [1..n] , n `mod` x ==0 ]

isprime :: Int -> Bool 
isprime n = length ( factor n ) == 2 

primes :: Int -> [Int]
primes n = [x | x <- [1..n] , isprime x]

可以喷素数啦

zip:捆绑从头两个列表,舍去匹配不上的

zip 和 Guard 真的是好兄弟啊

sorted :: Ord a => [a] -> Bool 
sorted xs = and [ x <= y  | (x,y) <- zip xs (tail xs)]

positions :: Eq a => a -> [a] -> [Int]
positions s xs = [ i | (x,i) <- zip xs [1..] , x==s]

 

 

Data.Char

两个常用函数:

ord :: Char -> Int 

ord 'a' = 97

chr :: Int -> Char 

chr 97 = 'a'

 

这次课老师布置了一个有点小难的作业:凯撒加密问题

posted @   liankewei123456  阅读(54)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2018-11-16 电阻 (resistance)
点击右上角即可分享
微信分享提示