数学对于计算机的重要性

上传人:206****923 文档编号:37529027 上传时间:2018-04-17 格式:DOC 页数:3 大小:33.50KB
返回 下载 相关 举报
数学对于计算机的重要性_第1页
第1页 / 共3页
数学对于计算机的重要性_第2页
第2页 / 共3页
数学对于计算机的重要性_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《数学对于计算机的重要性》由会员分享,可在线阅读,更多相关《数学对于计算机的重要性(3页珍藏版)》请在金锄头文库上搜索。

1、数学对于计算机的重要性数学对于计算机的重要性可能有很多朋友在网上看过 google 公司早几年的招聘广告,它的第一题如下了:first 10-digit prime found in consecutive digits ,e 中出现的连续的第一个 10 个数字组成的 质数。据说当时这个试题在美国很多地铁的出站口都有大幅广告,只要正确解答了这道题, 在浏览器的地 址栏中输入这个答案,就可以进入下一轮的测试,整个测试过程如同一个数 学迷宫,直到你成为 google 的一员。 又如 Intel 某年的一道面试题目:巴拿赫病故于 1945 年 8 月 31 日。他出生年份是他在 世某年年龄平方减去这

2、年年龄的差,问:他是哪年出生的?这道看似很简单的数学问题,你 能不能很快地解答呢? 下面则是一道世界第一大软件公司微软的招聘测试题:中间只隔一个数字的两个素数被 称为素数对,比如 5 和 7,17 和 19,证明素数对之间的数字总能被 6 整 除(假设这两个素 数都大于 6),现在证明没有由三个素数组成的素数对。这样的试题还有很多很多,这些题 目乍初看上去都是一些数学问题。但是世界上一些著名 的公司都把它们用于招聘测试,可 见它们对新员工数学基础的重视。数学试题与应用程序试题是许多大型软件公司面试中指 向性最明显的一类试题,这些试题就是考 察应聘者的数学能力与计算机能力。 某咨询公司的一名高级

3、顾问曾说:微软是一家电脑软件公司,当然要求其员工有一定的 计算机和数学 能力,面试中自然就会考察这类能力。微软的面试题目就考察了应聘人员对 基础知识的掌握程度、对基础知识的应用能力,甚至暗含了对计算机基本原理的考察。所 以,这样的面试题目的确很“毒辣”,足以筛选到合适的人。 四川大学数学学院的曹广福教授曾说过:“一个大学生将来的作为与他的数 学修养有很 大的关系”。大学计算机专业学生都有感触,计算机专业课程中最难的几门课程莫过于离散 数学、编译原理、数据结构,当然像组合数学、密码学、计算 机图形学等课程也令许多人 学起来相当吃力,很多自认为数据库学得很好的学生在范式、函数依赖、传递依赖等数学

4、性比较强的概念面前感到力不从心,这些都是因 为数学基础或者说数学知识的缺乏所造成 的。 数学是计算机的基础,这也是为什么考计算机专业研究生数学都采用最难试题(数学一)的原因,当然这也能促使一些新的交叉学科如数学与应用软件、信息与计算科学专业等飞速 发展。许多天才程序员本身就是数学尖子,众所周知,BillGates 的数学成绩一直都很棒, 他甚至曾经期望当一名数学教授,他的母校湖滨中学的数学系主任弗雷福?赖特曾这样 谈起过他的学生:“他能用 一种最简单的方法来解决某个代数或计算机问题,他可以用数学 的方法来找到一条处理问题的捷径,我教了这么多年的书,没见过像他这样天分的数学奇 才。他甚至 可以和

5、我工作过多年的那些优秀数学家媲美。当然,比尔也各方面表现得都很 优秀,不仅仅是数学,他的知识面非常广泛,数学仅是他众多特长之一”。影响一代中国程 序人的金山软件股份有限公司董事长求伯君当年高考数学成绩满分进一步说明了问题。很 多数学基础很好的人,一旦熟悉了某种计算机语言,他可以很快地理 解一些算法的精髓, 使之能够运用自如,并可能写出时间与空间复杂度都有明显改善的算法。 程序设计当中解决的相当一部分问题都会涉 及各种各样的科学计算,这需要程序员具 有什么样的基础呢?实际问题转换为程序,要经过一个对问题抽象的过程,建立起完善的数 学模型,只有这样,我们才能建 立一个设计良好的程序。从中我们不难看

6、出数学在程序设 计领域的重要性。算法与计算理论是计算机程序设计领域的灵魂所在,是发挥程序设计者 严谨,敏锐思维的 有效工具,任何的程序设计语言都试图将之发挥得淋漓尽致。 程序员需要一定的数学修养,不但是编程本身的需要,同时也是培养逻辑思 维以及严 谨的编程作风的需要。数学可以锻炼我们的思维能力,可以帮助我们解决现实中的问题。可以帮助我们更高的学习哲学。为什么经常有人对一些科学计算程 序一筹莫展,他可以读 懂每一行代码,但是却无法预测程序的预测结果,甚至对程序的结构与功能也一知半解, 给他一个稍微复杂点的数学公式,他可能就不知道怎么把它变成计算机程序。很多程序员 还停留在做做简单的 MIS,设计

7、一下 MDI,写写简单的 Class 或用 SQL 语句实现查询等基 础的编程工作上,对于一些 需要用到数学知识的编程工作就避而远之,当然实现一个累加 程序或者一个税率的换算程序还是很容易的,因为它们并不需要什么高深的数学知识。 一名有过 10 多年开发经验的老程序员曾说过:“所有程序的本质就是逻辑。技术你已经 较好地掌握了,但只有完成逻辑能力的提高,你才能成为一名职业程序 员。打一个比方吧, 你会十八班武艺,刀枪棍棒都很精通,但就是力气不够,所以永远都上不了战场,这个力 气对程序员而言就是逻辑能力(其本质是一个人 的数学修养,注意,不是数学知识)。 ” 程序员的数学修养不是一朝一夕就可以培养

8、的。数学修养与数学知识不一样,修养需 要一个长期的过程,而知识的学习可能只是一段短暂的时间。下面是一些我个人对于程序 员怎么样提高与培养自己的数学修养的基本看法。 首先,应该意识到数学修养的重要性。作为一个优秀的程序员,一定的数学修养是十 分重要也是必要的。数学是自然科学的基础,计算机科学实际上是数学的一个 分支。计算 机理论其实是很多数学知识的融合,软件工程需要图论,密码学需要数论,软件测试需要 组合数学,计算机程序的编制更需要很多的数学知识,如集合 论、排队论、离散数学、统 计学,当然还有微积分。计算机科学一个最大的特征是信息与知识更新速度很快,随着数 学知识与计算机理论的进一步结合,数据

9、挖掘、 模式识别、神经网络等分支科学得到了迅 速发展,控制论、模糊数学、耗散理论、分形科学都促进了计算机软件理论、信息管理技 术的发展。严格的说,一个数学基 础不扎实的程序不能算一个合格的程序员,很多介绍计 算机算法的书籍本身也就是数学知识的应用与计算机实现手册。 其次,自身数学知 识的积累,培养自己的空间思维能力和逻辑判断能力。数学是一门 分支众多的学科,我们无法在短暂的一生中学会所有的数学知识,像泛函理论、混沌理论 以及一些 非线性数学问题不是三五几天就可以掌握的。数学修养的培养并不在与数学知识 的多少,但要求程序员有良好的数学学习能力,能够很快地把一些数学知识和自己正 在解 决的问题联系

10、起来,很多理学大师虽然不是数学出身,但是他们对数学有很强的理解能力 和敏锐的观察力,于是一系列新的学科诞生了,如计算化学、计算生物 学、生物信息学、 化学信息学、计算物理学,计算材料学等等。数学是自然学科的基础,计算机技术作为理 论与实践的结合,更需要把数学的一些精髓融入其中。从 计算机的诞生来看它就是在数学 的基础上产生的,最简单的 0、1 进制就是一个古老的数学问题。程序设计作为一项创造性 很强的职业,它需要程序员有一定的数学 修养,也具有一定的数学知识的积累,可以更好 地把一些数学原理与思想应用于实际的编程工作中去。学无止境,不断的学习是提高修养 的必经之路。第三,多在实 践中运用数学。

11、有些高等学校开设了一门这样的课程数 学建模 。我在大学时期也曾学过,这是一门内容很丰富的课程。它把很多相关的学科与数 学都联系在 一起,通过很多数学模型来解决实际的生产生活问题,很多问题的解决需要计 算机程序来实现。我在大学和研究生阶段都参加过数学建模竞赛,获得了不少的经验, 同 时也进一步提高了自己的数学修养。实际上,现在的程序设计从某些角度来看就是一个数 学建模的过程,模型的好坏关系到系统的成败,现在数学建模的思想已经 用于计算机的许 多相关学科中,不单只是计算机程序设计与算法分析。应该知道,数学是一门需要在实践 中展示其魅力的科学,而计算机程序也是为帮助解决实际问题而编制的,因此,应该尽

12、量 使它们结合起来,在这个方面,计算机密码学是我认为运用数学知识最深最广泛的,每一 个好的加密算法后面都有一个数学理论的支 持,如椭圆曲线、背包问题、素数理论等。作 为一名优秀的程序员,应该在实际工作中根据需要灵活运用数学知识,培养一定的数学建模能力,善于归纳总结,慢慢 使自己的数学知识更加全面,数学修养得到进一步提高。 第四,程序员培养制度与教学的改革。许多程序员培养体制存在很多缺陷,一开 始就 要求学员能够快速精通某种语言,以语言为中心,对算法的核心思想与相关的数学知识都 一笔带过,讲得很少,这造成很多程序员成为背程序的机器,这样不利 于程序员自身的快 速成长,也不利于程序员解决新问题。我

13、在长期的程序员培训与计算机教学工作采用了一 些与传统方式不一致的方法,收到了一定的效果。很多初 学程序的人往往写程序时有时候 会有思维中断,或者对一些稍难的程序觉得无法下手,我采用了一些课前解决数学小问题 的方法来激励大家的学习兴趣,这些小问题 不单单是脑筋急转弯,其中不少是很有代表意 义的数学思考题。通过数学问题来做编程的热身运动,让学员在数学试题中激发自己的思 维能力,记得有位专家曾经说 过,经常做做数学题目会使自己变聪明,很长时间不去接触 数学问题会使自己思维迟钝。通过一些经典的数学问题来培养学员的思维的严谨性和跳跃 性。很多人可能 不以为然,其实有些看似简单的问题并不一定能够快速给出答

14、案,大脑也 在不断的运用中变更加灵活的。不信吗?大家有兴趣可以做做下面这道题目,看看能不能在 1 分钟之内想到答案,这只是一道小学数学课后习题。很多人认为自己的数学基础很好, 但是据说这道题目 90%以上的人不能在一个小时内给出正确答案。 证明:AB+ACDB+DC(D 为三角形 ABC 的一个内点)。 最后,多学多问,多看好书,看经典。我在这里向大家推荐两部可能大家已经很熟悉 的经典的计算机算法教材,它们中间很多内容其实就是数学知识的介绍。第一 部是算法 导论 ,英文名称:Introduction to Algorithms,作者:Thomas H. Cormen,Charles E. Le

15、iserson ,Ronald L. Rivest ,Clifford Stein。本书的主要作者来自麻省理工大学计算机,作者之一 Ronald L.Rivest 由于其在公开秘钥密码算法 RSA 上的贡献获得了图灵奖。这本书目前是算 法的标准教材,美国许多名校的计算机系都使用它,国内有些院校也将 本书作为算法课程 的教材。另外许多专业人员也经常引用它。本书基本包含了所有的经典算法,程序全部由 伪代码实现,这更增添了本书的通用性,使得利用各种程 序设计语言进行程序开发的程序 员都可以作为参考。语言方面通俗,很适合作为算法教材和自学算法之用。另一部是很多 人都应该知道的 Donald.E.Knu

16、th 所著计算机程序设计艺术 ,英文名称:The Art of Computer Programming。 Donald.E.Knuth 人生最辉煌的时刻在斯坦福大学计算机系渡过,美国计算机协会图灵 奖的获得者,是本领域内当之无愧的泰斗。有戏言称搞计算机 程序设计的不认识 Knuth 就 等于搞物理的不知道爱因斯坦,搞数学的不知道欧拉,搞化学的不知道道尔顿。被简称为 TAOCP 的这本巨著内容博大精深,几乎涵盖了计算机程序设计算法与理论最重要的内容。 现在发行的只有三卷,分别为基础运算法则,半数值算法,以及排序和搜索(在写本文之际, 第四卷已经出来了, 我也在第一时间抢购了一本)。本书结合大量数学知识,分析不同应 用领域中的各种算法,研究算法的复杂性,即算法的时间、空间效率,探讨各种适用算法 等,其 理论和实践价值得到了全世界计算机工作者的公认。书中引入的许多术语、得到的 许多结论都变成了计算机领域的标准术语和被广泛引用的结果。另外,作者对有关 领域的 科学发展史也有深入研究,因此本书介绍众多研究成果的同时,也对其历史渊

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号