问题描述:
The sum of the squares of the first ten natural numbers is,
12+ 22+ ... + 102= 385
The square of the sum of the first ten natural numbers is,
(1 + 2 + ... + 10)2= 552= 3025
Hence the difference between the sum of the squares of the first ten natural numbers and the square of the sum is 3025385
= 2640.
Find the difference between the sum of the squares of the first one hundred natural numbers and the square of the sum.
(ns euler-problem-6.core
(:use [clojure.contrib.math]))
(defn square
[num]
(* num num))
(square 3)
(defn square-sum-version-1
[num]
(loop
[current-num 1M sum 0M]
(if (= current-num num)
(+ sum (square current-num))
(recur (inc current-num) (+ sum (square current-num))))))
(defn square-sum-version-2
[num]
(reduce + (map square (range 1M (inc num)))))
;(time (square-sum-version-1 1000000M))
;(time (square-sum-version-2 1000000M))
(defn sum-square-version-1
[num]
(loop
[current-num 1M add-sum 0M]
(if (= current-num num)
(square (+ add-sum current-num))
(recur (inc current-num) (+ current-num add-sum)))))
(defn sum-square-version-2
[num]
(square (reduce + (range 1M (inc num)))))
;(sum-square-version-1 10)
;(sum-square-version-2 10)
(defn dif-sum-square-with-square-sum
[num]
(abs (- (sum-square-version-1 num) (square-sum-version-1 num))))
(dif-sum-square-with-square-sum 100M)
经测试,尾递归版本的性能要好于延迟加载的版本,但是延迟加载程序简单明了!
分享到:
相关推荐
该存储库是使用Clojure解决Euler问题的支架。 它以有组织的结构生成规格和解决方案存根,从而使生活稍微好一些。 安装 如果尚未安装,则将其添加到您的路径中。 签出这个项目: $ git clone git@github....
Clojure骇客解决了Euler项目的问题。 目的是用惯用的Clojure编写功能解决方案。 用法 大多数解决方案都是完整的,并且完全独立地包含在具有“解决”功能的唯一名称空间中。 有些正在“进行中”。 执照 版权所有:...
欧拉计划 问题1-2、4、6、8-10、12、14、21、24-26、32、34、36、39、41、46、49、52、55-58、62、65的Clojure解决方案70-74、87、92、97、124、173-174、179、187、214运行解决方案使用以下命令行运行解决方案: ...
这本书不仅讲解了Clojure的基本语法和API,而且通过实例展示了如何使用Clojure解决实际问题。Halloway详细阐述了Clojure的REPL(Read-Eval-Print Loop)工作原理,以及如何利用它进行开发和测试。他还讨论了Clojure...
欧拉解决Clojure中的Euler项目问题的方法。 持续的爱好。执照版权所有:copyright:2012-2015 Dave Yarwood 在Eclipse Public License 1.0版下分发。
Clojure的设计目标是提供一个高效、并发、可移植的环境,适合解决现代软件开发中的复杂问题。在这个“Clojure编程乐趣”中,我们将深入探讨Clojure的核心概念和特性。 首先,Clojure强调函数式编程,这意味着程序被...
6. **Performance**: 当性能至关重要时,Clojure可以达到与手工编写的Java代码相当的执行速度。 这些特性使得Clojure在众多编程语言中脱颖而出,为开发者提供了强大的工具集来构建高效的应用程序。 #### 二、...
其次,Clojure 1.6 引入了更好的错误报告机制,使得开发者能够更快地定位和解决问题。此外,它还增强了ClojureScript的互操作性,使得在浏览器环境下的开发更为便捷。 Clojure的核心特性之一是其丰富的数据结构。...
使用Clojure编程,随着程序的增长,并不会变得更复杂难以理解,反而会变得更简单、表达性更强。Clojure鼓励开发者尝试在其他语言中过于复杂而通常不会尝试的事情,例如并发编程、不可变性和惰性数据结构。因为...
读者将通过实例学习如何运用Clojure解决实际问题,提升自己的编程技巧。 总的来说,《Programming Clojure 第三版》是一本全方位的Clojure指南,适合初学者和经验丰富的开发者。它涵盖了Clojure的所有重要方面,...
### Clojure入门教程知识...- 对于希望深入了解函数式编程或在JVM上寻找高效编程解决方案的开发者而言,Clojure是一个值得探索的选择。通过实践和社区的支持,学习者可以快速掌握Clojure的核心概念并应用于实际项目中。
- **数据结构和序列操作**:解释 Clojure 中常用的数据结构,如列表、向量、集合和映射,并展示如何使用这些结构进行数据处理。 - **函数式编程**:探讨 Clojure 如何支持纯函数式编程风格,包括高阶函数、闭包和...
Lacinia将Clojure的这些优点带入了GraphQL领域,允许开发者用熟悉的Clojure语法定义GraphQL类型、字段和解析器。这种结合使得开发者可以利用Clojure的宏系统来创建复杂的GraphQL schema,同时保持代码的可读性和可...
Clear, practical Clojure for the professional programmer Professional Clojure is the experienced developer's guide to functional programming using the Clojure language. Designed specifically to meet ...
[2009] Programming Clojure.(Stuart Halloway).[1934356336].pdf [2010] Functional Programming with Clojure - Simple Concurrency on the JVM.(Tim Berglund, Matthew McCullough).[193650202X].pdf [2010] ...
标题 "Clojure学习——使用clojure jdbc操作mysql" 指出的是一个关于使用Clojure编程语言通过Java Database Connectivity (JDBC) API来操作MySQL数据库的主题。Clojure是一种基于Lisp的函数式编程语言,它运行在Java...