一门编程语言,假设不能对你思考编程的方式产生影响。就不值得去学习。——  Alan Perlis

(define rember*

  (lambda (a list)

    (cond

      ((null? list) '())

      ((atom? (car list)) (cond 

                      ((eq? a (car list)) (rember* a (cdr list)))

                      (else (cons (car list) (rember* a (cdr list))))))

      (else (cons (rember* a (car list)) (rember* a (cdr list)))))))





(rember* 'cup '((coffee) cup ((tea) cup) (and (hick)) cup))



(define insertR*

  (lambda (new old l)

    (cond

      ((null? l) '())

      ((atom?

(car l)) (cond

                         ((eq?

(car l) old) (cons old (cons new (cdr l))))

                         (else (cons (car l) (insertR* new old (cdr l))))))

      (else (cons (insertR* new old (car l)) (insertR* new old (cdr l)))))))



(insertR* 'roast 'chuck '((how much (wood))

                          could

                          ((a (wood) chuck))

                          (((chuck)))

                          (if (a) ((wood chuck)))

                          could chuck wood))



(define occur*

  (lambda (a l)

    (cond

      ((null?

l) 0)

      ((atom?

(car l)) (cond ((eq? a (car l)) (+ 1 (occur* a (cdr l))))

                             (else (occur* a (cdr l)))))

      (else (+ (occur* a (car l)) (occur* a (cdr l)))))))



(occur* 'banana '((banana) (split ((((banana ice)))

                                   (cream (banana))

                                   sherbet))

                           (banana)

                           (bread)

                           (banana brandy)))

(define subst*

  (lambda (new old l)

    (cond

      ((null? l) '())

      ((atom? (car l)) (cond

                         ((eq? old (car l)) (cons new (subst* new old (cdr l))))

                         (else (cons (car l) (subst* new old (cdr l))))))

      (else (cons (subst* new old (car l)) (subst* new old (cdr l)))))))

(subst* 'orange 'banana '((banana) (split ((((banana ice)))

                                   (cream (banana))

                                   sherbet))

                           (banana)

                           (bread)

                           (banana brandy)))



(define insertL*

  (lambda (new old l)

    (cond

      ((null? l) '())

      ((atom?

(car l)) (cond

                        ((eq?

old (car l)) (cons new (cons old (insertL* new old (cdr l)))))

                        (else (cons (car l) (insertL* new old (cdr l))))

                        ))

      (else (cons (insertL* new old (car l)) (insertL* new old (cdr l)))))))



(insertL* 'pecker 'chuck '((how much (wood))

                           could

                           ((a (wood) chuck))

                           (((chunck)))

                           (if (a) ((wood chuck)))

                           (could chuck wood)))



(define member*

  (lambda (a l)

    (cond

      ((null? l) #f)

      ((atom? (car l)) (cond

                         ((eq?

(car l) a) #t)

                         (else (member* a (cdr l)))))

      (else (or (member* a (car l))

                (member* a (cdr l)))))))



(member* 'chips '((potato) (chips ((with) fish)(chips))))

全民Scheme(2):来自星星的你的更多相关文章

  1. 全民Scheme(0):lat的定义

    接下来我会写一写Scheme的学习笔记.嗯,Scheme是属于小众的语言,但合适用来教学的. 什么是lat,就是遍历list里的每一个S-expression,假设发现当中某个不是atom的,则返回f ...

  2. 全民Scheme(1):数字游戏

    刚刚看到两句话,感觉不错,分享给大家: 1.用户的问题.就是我们的问题 2.做一些用户想要的东西 (define add1 (lambda (x) (+ 1 x))) (define sub1 (la ...

  3. Partition:Partiton Scheme是否指定Next Used?

    在SQL Server中,为Partition Scheme多次指定Next Used,不会出错,最后一次指定的FileGroup是Partition Scheme的Next Used,建议,在执行P ...

  4. Android业务组件化之URL Scheme使用

    前言: 最近公司业务发展迅速,单一的项目工程不再适合公司发展需要,所以开始推进公司APP业务组件化,很荣幸自己能够牵头做这件事,经过研究实现组件化的通信方案通过URL Scheme,所以想着现在还是在 ...

  5. iOS - URL Scheme 操作

    推荐JLRoutes路由跳转 NSScanner 在寻找更加灵活的页面跳转和通知,我遇见了JLRoutes,从而学习使用URL Scheme来定义界面入口.以前从来没有使用过,不过很多大厂和流行的框架 ...

  6. 自定义 URL Scheme 完全指南

    本文由 Migrant 翻译自 The Complete Tutorial on iOS/iPhone Custom URL Schemes,转载请注明出处. 注意: 自从自定义 URL 的引入,本文 ...

  7. JS魔法堂:Data URI Scheme介绍

    一.前言 上周五公司内部的Any Topic Conf.上我和同事们分享了这个主题,有同事说这个有用,有同事说这个没啥用,后来还延伸到网站性能的话题上,大家讨论的激烈程度让我觉得这次选题还不错.本篇先 ...

  8. CSS魔法堂:小结一下Box Model与Positioning Scheme

    前言  对于Box Model和Positioning Scheme中3种定位模式的细节,已经通过以下几篇文章记录了我对其的理解和思考.  <CSS魔法堂:重新认识Box Model.IFC.B ...

  9. Project、Target、Workspace and Scheme

    前言 今天有人问我Target和Project是什么关系?额...学习iOS开发都知道Target和Project的关系.这里我就简单的做了一个总结,而且加入的Scheme和Workspace.如果不 ...

随机推荐

  1. disconf-web 分布式配置管理平台

    一.需求 实现分布式配置中心:(1)集中管理外部依赖的服务配置和服务内部配置(2)提供web管理平台进行配置和查询(3)支持服务注册与发现(4)支持客户端拉取配置(5)支持订阅与发布,配置变更主动通知 ...

  2. Linux中建立软raid

    Linux内核中有一个md(multiple devices)模块在底层管理RAID设备,它会在应用层给我们提供一个应用程序的工具mdadm. mdadm用于构建.管理和监视Linux MD设备(即R ...

  3. 我的OI生涯 第四章

    第四章 晚上来机房的人越来越多了,我也注意到一个常年独自坐在一个角落的男人————郝哥. 郝哥为人很安静,只是那时我还不知道他好不好,就没有与他交流过什么,这个优秀的男人以后我们还会提到,这里先不讲. ...

  4. [NOIP2017]列队(线段树/裂点splay)

    考虑n=1的做法,就是支持: 1.在线删一个数 2.在结尾加一个数 3.查询序列的第y个数 用线段树记录区间内被删元素的个数,可以通过线段树上二分快速得解,对于新增的数,用vector记录即可. 对于 ...

  5. 检测使用内存memory_get_usage,执行时间microtime

    最近经常用一些扩展,适当比较所占内存,还有一些扩展执行时间长,检测一下每步的执行时间,可以加以修正调整一下源码 查看运行时间 microtime() #返回当前 Unix 时间戳和微秒数. echo ...

  6. JavaScript学习笔记 isPrototypeOf和hasOwnProperty使用区别

    1.isPrototypeOf isPrototypeOf是用来判断指定对象object1是否存在于另一个对象object2的原型链中,是则返回true,否则返回false. 格式如下: object ...

  7. CROC 2016 - Qualification C. Hostname Aliases map

    C. Hostname Aliases 题目连接: http://www.codeforces.com/contest/644/problem/C Description There are some ...

  8. Android 动画——Layout Animations布局动画

    Layout Animations主要使用LayoutTransition为布局的容器设置动画,当容器中的视图层次发生变化时存在过渡的动画效果. LayoutTransition This class ...

  9. iOS学习之sqlite的创建数据库,表,插入查看数据

    目录(?)[-] 新建项目sqliteDemo添加使用sqlite的库libsqlite3dylib sqlite 的方法 获取沙盒目录并创建或打开数据库 创建数据表 插入数据 查询数据库并打印数据 ...

  10. 给WebAPI的REST接口添加测试页面(二)

    在上篇文章中,我对Swagger-UI的基本功能进行了一些介绍,今天在这里介绍一下如何在WebAPI中集成Swagger-UI.这里以一个简单的CRUD的REST服务为例. /// <summa ...