首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Lisp的本质(The Nature of Lisp)学习思考

比如说: Lisp的括号只是表面现象; Lisp的代码和数据的表达方式没有差别, 而且比XML语法高明许多, 所以有无穷的好处; Lisp有强大无比的元语言能力, 程序员可以写出自我维护的代码; Lisp...我内心体会到一种神圣的情感, 一瞬间的顿悟, 几乎使我对电脑科学的观念发生了根本的改变。 顿悟的那一刻, 我成了Lisp的崇拜者。...你好, Lisp 到此刻为止, 我们所知的关于Lisp的指示可以总结为一句话: Lisp是一个可执行的语法更优美的XML, 但我们还没有说Lisp是怎样做到这一点的, 现在开始补上这个话题。...这两种方法的差别在于, Lisp使我们达到了一个更高层次的抽象, 我们不再受语言解析器本身的限制, 比较一下用Java库直接写的构造脚本和用Ant写的构造脚本其间的差别。...好在现在事情正在发生变化, Lisp的资源正在迅速增加, 随着时间推移, Lisp将会越来越受关注。Lisp使人超越平庸, 走到前沿。

1.8K60

走进 racket(lisp) 的世界

racket是一个lisp [1] 家族的语言,祖上是common lisp [2] 对立的阵营scheme [3],起初为教学的目的而创立。...像lisp这样能够编写macro的语言,如果无法调试macro,简直就是一场灾难,当时玩clojure进行不下去也是稍微复杂一点的macro总写不对有关(我的功力实在有限),但DrRacket的 "Macro...racket的其它优点,都或多或少跟lisp有关,这个我觉得自己不必多讲。...如果你看过「黑客与画家」,就知道Paul Graham近乎偏执地把一切溢美之词都给了lisp,说它是最有表现力的语言,说lisp是自己公司成功的"secret weapon"。...对于lisp的优点,比如说一切皆为表达式,一切表达式皆可计算为一个值或一个list,语言可以在任何时候(读取,编译,执行)可用等等,可以看阮一峰的博文「为什么Lisp语言如此先进」[5],这里就不赘述。

2.5K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使数组唯一的最小增量

    使数组唯一的最小增量 题目描述 给定整数数组 A,每次 move 操作将会选择任意 A[i],并将其递增 1。 返回使 A 中的每个值都是唯一的最少操作次数。...可以看出 5 次或 5 次以下的 move 操作是不能让数组的每个值唯一的。...这种时间复杂度大,可以为 O(n^2) 第二种:排序 先排序 遍历数组 用一个队列来保存当前重复需要递增的一些值 找到前一个值和当前值差值大于1的,说明可以将之前重复的值递增到 [A[i - 1] +...遍历完成后,队列不为空,则可以将剩下的值依次递增为 [A[n−1]+1,∞)中的数字, A[n−1]代表数组的最后一个值。 解题方法 直接用排序实现。...[prev+1,∞)中的数字,prev代表数组的最后一个值。

    65930

    【算法】使数组有序的最小交换次数

    相关参考: 数组排序 使得交换次数最少 ,该文章中代码出现了一处错误,看起来作者好像很长时间没有更新了,在此纠正下。 TsReaper-6235....逐层排序二叉树所需的最少操作数目,参考该题解的评论区的作者解答,进行纠正。 贪心思想,每一步使得对应元素放到它该放的位置。...先将要排序的数组复制一份,然后将其排序,使用哈希表记录排序后的数组对应元素与其对应下标。 遍历原数组与排序后的数组,如果对应下标不相等,则根据哈希表记录该元素的下标进行交换。...} } return cnt; } 注意上述代码中,第二个for循环使用的是while,使用if会跳过某些元素。...逐层排序二叉树所需的最少操作数目 先层序遍历获取每层元素,然后对每层元素求有序最小的操作数目。

    42820

    删除最短的子数组使剩余数组有序

    题目描述 解题思路 代码 复杂度分析 GitHub LeetCode 项目 题目描述 题目链接 给你一个整数数组 arr ,请你删除一个子数组(可以为空),使得 arr 中剩下的元素是 非递减 的。...一个子数组指的是原数组中连续的一个子序列。 请你返回满足题目要求的最短子数组的长度。...另一个正确的解为删除子数组 [3,10,4] 。 示例 2: 输入:arr = [5,4,3,2,1] 输出:4 解释:由于数组是严格递减的,我们只能保留一个元素。...所以我们需要删除长度为 4 的子数组,要么删除 [5,4,3,2],要么删除 [4,3,2,1]。...比如对于数组 1,2,3,10,4,2,3,5,先找到左边排序的段 1,2,3,10,右边排序的段 2,3,5,对于左边数组的第 i 位,和右边数组的第 j 位进行比较 如果 numi数组索引

    52800

    【Leetcode-1574.删除最短的子数组使剩余数组有序(C语言)】

    Leetcode-1574.删除最短的子数组使剩余数组有序 Leetcode-1574. 题目:给你一个整数数组 arr ,请你删除一个子数组(可以为空),使得 arr 中剩下的元素是非递减的。...一个子数组指的是原数组中连续的一个子序列。请你返回满足题目要求的最短子数组的长度。...首先我们的思路是双指针,一个从头部开始,一个从尾部开始; 尾部的先往前找,找到开始递增的临界点记录下来;然后再依次与头部的指针相对比; 下面我们直接看代码以及注释: int findLengthOfShortestSubarray...(int* arr, int arrSize) { int j = arrSize - 1; //j从尾部开始往前找(尾部往前是递减的),找到开始递增的的临界点的下标...,也要保证arr[i] > arr[i + 1]并且数组不越界,如果不满足条件,直接跳出循环,返回的这个len值就是最优解 if (arr[i] > arr[i + 1] && i

    11010

    最少移动次数使数组元素相等

    最少移动次数使数组元素相等 1. 题目描述 给定一个非空整数数组,找到使所有数组元素相等所需的最小移动数,其中每次移动可将选定的一个元素加1或减1。您可以假设数组的长度最多为10000。...例如: 输入: [1,2,3] 输出: 2 说明:只有两个动作是必要的(记得每一步仅可使其中一个元素加1或减1): [1,2,3] => [2,2,3] => [2,2,2] 来源:力扣(LeetCode...题解 这道题偏数学一点,我们从常理推论的角度去想,如果要找到使所有数组元素相等的最小移动数。那么这个元素就是数组其他元素离它距离之和最近的数,这个元素就是数组中的中位数。...2.1 解题步骤 对数组元素进行排序 找到中位数 遍历数组,计算所有元素与中位数的距离 累加距离,即可得到目标值。...int result = 0; // 遍历数组,计算与中位数的距离 for (int num : nums) { result

    46930

    使数组元素相等的减少操作次数(map)

    题目 给你一个整数数组 nums ,你的目标是令 nums 中的所有元素相等。完成一次减少操作需要遵照下面的几个步骤: 找出 nums 中的 最大 值。...返回使 nums 中的所有元素相等的操作次数。...示例 1: 输入:nums = [5,1,3] 输出:3 解释:需要 3 次操作使 nums 中的所有元素相等: 1. largest = 5 下标为 0 。nextLargest = 3 。...示例 3: 输入:nums = [1,1,2,2,3] 输出:4 解释:需要 4 次操作使 nums 中的所有元素相等: 1. largest = 3 下标为 4 。nextLargest = 2 。...解题 使用 map 计数 找到末尾最大的两个数字,将最大的数字转为次大的数字即可,然后删除最大的,循环直到map只有一个数字 class Solution { public: int reductionOperations

    37320

    调整数组顺序使奇数位于偶数前面

    题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。...解法一 书中作者提到一种初始的做法是,从头扫描整个数组,如果遇到偶数,则拿出这个数,并且把整个数组的数据都向前挪动一位,再把拿出的数放到末尾。...,创建一个新的数组,从头扫描,遇到偶数放后边,遇到奇数放前边。...扫描结束后,再将数组内容拷贝到原数组,这样整个时间复杂度为(n),而空间复杂度也为O(n),这样的方法实现简单,也不容易出错。...快速排序中,有一个分区操作,是将整个数组大于基准的部分,放右边,而小于基准的部分放右边,即根据基准,将数组一分为二。其实在这里,同样可以参考这个思路,只不过跟基准比大小,变成了判断是奇还是偶。

    89710
    领券