【杂谈】如果让莎士比亚、海明威编写JavaScript代码

2023-11-03 10:21

本文主要是介绍【杂谈】如果让莎士比亚、海明威编写JavaScript代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么80%的码农都做不了架构师?>>>   hot3.png

最近,我做了一个梦,我请海明威和其他四位文学名人替我编写JavaScript代码,一个函数返回一个给定长度的斐波纳契数列。有趣地是,他们每个人都以不同的方式完成了这一题,并且都做的很好——只是我想说,每个解决方案工作起来都好比广告(即使是Andre Breton的),后来我又请包括海明威在内的7名文豪用JavaScript来编写阶乘,似乎一切都那么神奇,但他们都成功地完成了,大家不妨来看看结果吧。

一、实现斐波纳契数列

1.欧内斯特·海明威(Ernest Hemingway 美国作家) 

代表作:《老人与海》《太阳照样升起》《永别了,武器》《丧钟为谁而鸣》

function fibonacci(size) {var first = 0, second = 1, next, count = 2, result = [first, second];if(size < 2)return "the request was made but it was not good"while(count++ < size) {next = first + second;first = second;second = next;result.push(next);}return result;
}

简洁明了的代码,没有任何多余的字母和变量,没有精心设计的逻辑和聪明的变量命名,非常平淡地表明了它是做什么的,仅此而已,这就是海明威的魅力之处。

2.威廉&middot;莎士比亚(William Shakespeare 英国诗人、戏剧家)

代表作: 《哈姆雷特》《奥赛罗》《李尔王》《罗密欧与朱丽叶》等

function theSeriesOfFIBONACCI(theSize) {//a CALCKULATION in two acts.//employ'ng the humourous logick of JAVA-SCRIPTE//Dramatis Personaevar theResult;//an ARRAY to contain THE NUMBERSvar theCounter;//a NUMBER, serv'nt to the FOR LOOP//ACT I: in which a ZERO is added for INITIATION//[ENTER: theResult]//Upon the noble list bestow a zerovar theResult = [0];//ACT II: a LOOP in which the final TWO NUMBERS are QUEREED and SUMM'D//[ENTER: theCounter]//Commence at one and venture o'er the numbersfor (theCounter = 1; theCounter < theSize; theCounter++) {//By divination set adjoining memberstheResult[theCounter] = (theResult[theCounter-1]||1) + theResult[Math.max(0, theCounter-2)];}//'Tis done, and here's the answer.return theResult;//[Exuent]
}


大家可以看看莎士比亚是如何使用抑扬格五音步编写注释的。熟悉他戏剧的朋友应该对抑扬格五音步非常熟悉吧。

3.安德烈&middot;布勒东(Andre Breton 法国诗人)

代表作:《超现实主义宣言》

function Colette(umbrella) {var staircase = 0, galleons = 0, brigantines = 1, armada = [galleons, brigantines], bassoon;Array.prototype.embrace = [].push;while(2 + staircase++ < umbrella) {bassoon = galleons + brigantines;armada.embrace(brigantines = (galleons = brigantines, bassoon));}return armada;
}

整个解决方案的逻辑非常清晰、优雅,在galleons、brigantines、bassoons这三个之间,使用逗号操作符对它们进行同时转移。

4.罗贝托&middot;波拉尼奥(Roberto Bolano 智利小说家、诗人)

代表作:《荒野侦探》《2666》

function LeonardoPisanoBigollo(l) {if(l < 0) {return "I'd prefer not to respond. (Although several replies occur to me)"}/**///Everything is getting complicated.for (var i=2,r=[0,1].slice(0,l);i<l;r.push(r[i-1]+r[i-2]),i++)/**///Here are some other mathematicians. Mostly it's just nonsense.rationalTheorists = ["Archimedes of Syracuse", "Pierre de Fermat (such margins, boys!)", "Srinivasa Ramanujan", "Rene Descartes", "Leonhard Euler", "Carl Gauss", "Johann Bernoulli", "Jacob Bernoulli", "Aryabhata", "Brahmagupta", "Bhaskara II", "Nilakantha Somayaji", "Omar Khayy&aacute;m", "Muhammad ibn Mūsā al-Khwārizmī", "Bernhard Riemann", "Gottfried Leibniz", "Andrey Kolmogorov", "Euclid of Alexandria", "Jules Henri Poincar&eacute;", "Srinivasa Ramanujan", "Alexander Grothendieck (who could forget?)", "David Hilbert", "Alan Turing", "von Neumann", "Kurt G&ouml;del", "Joseph-Louis Lagrange", "Georg Cantor", "William Rowan Hamilton", "Carl Jacobi", "&Eacute;variste Galois", "Nikolay Lobachevsky", "Rene Descartes", "Joseph Fourier", "Pierre-Simon Laplace", "Alonzo Church", "Nikolay Bogolyubov"]/**///I didn't understand any of this, but here it is anyway.return r/**///Nothing happens here and if it does I'd rather not talk about it.
}

长短不齐的段落,缺少分号,使用隐式全局变量——对每一个变量都做进一步深入的说明。

5. 查尔斯&middot;狄更斯(Charles Dickens 英国小说家)

代表作:《匹克威克外传》《雾都孤儿》《 双城记 》等

function mrFibbowicksNumbers(enormity) {var assortment = [0,1,1], tally = 3, artfulRatio = 1.61803;while(tally++ < enormity) {//here is an exceedingly clever deviceassortment.push(Math.round(assortment[tally-2] * artfulRatio));}//should there be an overabundance of elements, a remedy need be appliedreturn assortment.slice(0, enormity);
}


从代码中可以看出,他没有体会到斐波那契数列的基本理念,而是采用乘法解决。代码里也有些有趣的命名,但缺乏核心地理解。

二、实现factorial(n)阶乘 

以上是这些著名的作家用JavaScript编写斐波那契数列,下面再让我们看看,作家们是如何用JavaScript/CoffeeScript编写factorial(n)的。

1. 杰克&middot;凯鲁亚克(Jack Kerouac 美国小说家)

代表作:《在路上》《贩毒者》等

/*...the only numbers for me are the mad ones, take forty-three like a
steam engine with a talky caboose at the end*/n = 43,/*and that lanky
fellow in a cocked fedora*/r = 1/*then back to our number, our mad
number, mad to become one*/while (n > 1)/*mad to descend*/n--,/*mad
to multiply*/r = r * n/*and at the end, you see the blue center-light
pop, and everybody goes 1.4050061177528801e+51...*/
r

上面代码只能返回43的阶乘,如果想要实现另一个数的阶乘,你还需重写代码。不过,最值得注意地是,注释和代码几乎没有区别,无法分辨,从侧面反映了Kerouac的风格,很长、狂野和狂想式的流露。

2.塞缪尔&middot;约翰逊(Samuel Johnson 英国作家、诗人)

代表作:《英语大辞典》《伦敦》《人类欲望的虚幻》等

# In which various NUMBERS are summon'd by
# means of ELECTRONICK CONJURY
factorial = (n) -># All argument is against it; yet all belief is for itreturn 1 unless n# Ingenious sophistry to prove the palp'bly OBVIOUSreturn 1 if n is 1# Recursion (n.)# a program that calls 'pon itself in the manner of# a dog returning unto its VOMITreturn n * factorial n - 1

整段代码比较稀疏,中间也掺杂着Johnson的精言妙语:其中,他也对factorial(0)应该为1进行了怀疑,他应该用一个完整的句子来表达factorial(1)就是1,从其字典里进行推测,完成了一个具有讽刺定义的递归解除。

Johnson的整个解决方案充满着艺术和模仿的结合——带有整洁表达式地温和的自我嘲讽和真正美丽的混合。

3.詹姆斯&middot;乔伊斯(James Joyce 爱尔兰作家、诗人)

代表作:《尤利西斯》

function hacktorial(integette) {var nonthings = [undefined, null, false, 0, '', NaN];var resultution = 1;if (integette == 0) {//behold the strangerous zeroine!resultution = 1;} else {while (integette > 1)//caligulate by multicapablesresultution = resultution * integette--;}with(resultution) {var duodismal =  Function('return this').call(toString(12));var disemvowel = Function("n","return n?parseInt(n,12):'0'")return [disemvowel(duodismal.slice(0,-1)),'shillings and',disemvowel(duodismal[duodismal.length-1]), 'pence'].join(' ');}//klikkaklakkaklaskaklopatzklatschabattacreppycrottygraddahappluddyappladdypkonpkot!
}

Joyce不仅仅是解决了阶乘问题,前半部分代码已经解决了这个问题,但Joyce坚决把结果转换为当时的货币:先令和便士。

结果:

hacktorial(3)//"0 shillings and 6 pence"
hacktorial(4)//"2 shillings and 0 pence"
hacktorial(7)//"420 shillings and 0 pence"
hacktorial(21)//"4257578514309120000 shillings and 0 pence"

4.理查德&middot;费曼(Richard Feynman美国物理学家)

代表作:《费曼物理学讲义》《物理之美》

//using Ramanujan's approximation
function fractorail(n){with(Math) {var r = sqrt(PI)*pow(n/E,n);r *= pow(8*pow(n, 3) + 4*(n*n) + n + 1/30, 1/6);return r;}
}

费曼的工作的特点是具有大胆的创意和非常古怪的才华,从它所编写的这段代码中也能看出。

结果,不要担心一些“舍入误差”,如果你非常熟悉JavaScript,你就应该知道:

fractorail(3);//6.00005
fractorail(1.1);//1.04671
fractorail(5.2);//169.40628

5. 阿瑟&middot;柯南&middot;道尔(Arthur Conan Doyle世界著名小说家)

代表作:《福尔摩斯探案集》《失落的世界》

"use strict";
//In solving a problem of this sort, the grand thing is to be able to reason backwards...
//some things are easier known than explained!
var caseHistory = new Object({2:2, 6:3});
function unfactorial(evidence){//first, humility!if (evidence === 1) {return "Watson, I am at a loss!"}//second, logical precedence!if(caseHistory[evidence]){//elementary!return caseHistory[evidence];}//third, eliminate the impossible!if(evidence === 0 || evidence % 24 !== 0) {return "charlatans!";}//fourth, deduction!var theDeduction, enumarator = evidence, denominator = 1;while(enumarator % denominator === 0) {enumarator = enumarator/denominator++;if (enumarator === denominator) {theDeduction = enumarator;}}theDeduction = theDeduction || "impostors";//What one man can invent another can discover!caseHistory[evidence] = theDeduction;//What remains, however improbable, must be the truth!return theDeduction;
}

正如大家想象的那样, 柯南道尔的设计过程是精确和认真有序的,此外,大家可能注意到,他让其应用程序在strict模式运行——容不得半点马虎。

6.简&middot;奥斯汀(Jane Austen 英国小说家)

代表作:《理智与情感》 《傲慢与偏见》

factorial = (function() {//I declare...var ledger = {};return function reckoning(quantity) {if (isNaN(quantity)) {console.log("I have not the pleasure of understanding you");return;}//It is a truth universally acknowledged that two values//can only be adjudged truly agreeable by means of ===if (quantity === 0) {return 1;}//Mr Crockford teaches that we be wary of inherited property...if (ledger.hasOwnProperty(quantity)) {return ledger[quantity];}//Pray persist until an answer is furnishedreturn ledger[quantity] = quantity * reckoning(quantity - 1);};
})();

Jane Austen解决方案的亮点之一是代码工艺和结构的完整性,主要体现在代码块的整洁上,她调用模块模式,隐藏历史数据(或ledger)在上层结构的文件夹里;第二个则是体现了Jane Austen的俏皮,甚至是颠覆性的,对power的讽刺和荒谬的约定。

7. 欧内斯特&middot;海明威(Ernest Hemingway 美国小说家)

代表作:《老人与海》《太阳照样升起》等

//Economy.
function factorial(n) {return n < 2 ? 1: factorial(n-1)*n;
}

代码足以说明一切。

我们从中所学到的

这些著名的小说家、诗人、戏剧家的伟大之处在于他们勇于开拓新方式,尝试新的技术并且打破我们一直所遵循的规律。

最优秀的英语作家具有着对规则的蔑视。——Steven Pinker

JavaScript作为最流行的编程语言之一,它的进步取决于开发者们地大胆创新、研究以及发现新模式,这样才能惠及更多的人。

各位开发者们,如果让你们喜欢的作家来编写JavaScript代码会是啥样呢?不妨一起探讨下吧。

转载于:https://my.oschina.net/maomi/blog/150134

这篇关于【杂谈】如果让莎士比亚、海明威编写JavaScript代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/337517

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.