计算机思维的逻辑基础:

计算机思维是指人们操作计算机时,计算机行使特定功能的运作方式。

逻辑基础则是指支撑事物运作的基本法则。

因而,计算机思维的逻辑基础可以理解为,计算机在行使特定功能时,其运作方式背后的法则——即“分离”。

不同于人脑的思维方式,计算机思维本身是不具有体现的。但是其行使法则之中与人脑最为不同的一点在于思想与方法、思想与对象、对象与方法的分离,这也是计算机能达到高效与高性能运算的逻辑基础。

接下来,举一例对上述描述中的“分离”进行详细阐述。

所谓思想与方法的分离,是指在人脑中,思想与方法的实现总是同时,换言之,即使大脑总是有意识地将其分离开来思考以达到更高地效率,但效果总不遂人意。但是通过硬件上地将方法的实践转移至计算机中,而将思考和总结方法的过程在人脑中实现(暂不考虑人工智能的实现)。这样通过将思想与方法分离的方式无疑可以极大提升执行效率,而这也是计算机思维的背后原理,即逻辑基础。

为什么说计算思维的核心是“构造”,而构造的任务是抽象与自动化:

首先解释计算思维,CMU周以真教授在《Computational Thinking》中说明“计算思维是运用计算机科学的基本理念,进行问题求解,系统设计以及理解人类行为。”这句话也说明了计算思维是一种思考方式,而并非是具体的知识。但计算机本身是无法思考的,故此处的探讨对象已经十分明显了,即计算思维是对人类提出的要求——通过人类将抽象而且复杂的问题,进行转化,从而转变成为一种可执行的重复性操作,即计算,并将此交给计算机去实现。而这中间的转变部分中,最为重要的部分便需要人类拥有计算思维参与,设计出尽可能更优质的算法,从而使计算机的执行更为高效。因此,计算思维的核心是“构造”,而以上这整个完整的过程,便被称为“人机转化”。

而计算思维的另一个特征是基于三个阶段的“3A”迭代过程:

  1. 1.   抽象(Abstraction):问题表示;
  2. 2.   自动化(Automation):解决方案表达;
  3. 3.   分析(Analyses):解决方案执行和评估。

接下来将对前两个方面进行一一解释与印证。

  1. 1.  抽象

抽象是指将现实生活中复杂难解的应用性问题,抽象成为可计算的问题。比如,让你统计一本牛津现代英汉双解词典中有多少个单词,则此时不考虑单词的字体,字号大小,出现的位置,仅仅提取了该问题中与单词数量相关的元素进行考虑,这便是一种意义上的抽象。而整体意义上的抽象,则指的是将现实生活的应用复杂问题中,提取出相应的空间关系,数量关系,逻辑关系等关系,并将其转换为数据结构,空间结构以及控制指示等具体结构与指令。抽象以问题重述的形式,将原问题转化成可解的问题,即为问题表示。

  1. 2.  自动化

在某种程度上,自动化是计算机的工作。而将此工作的执行的必要条件则是需要将自然语言转换成为计算机可执行的语言。因此,编程在某种程度上成为了自动化的替代。而自动化的核心是高效,假使计算机运行中仍然经常需要人工的控制与协调,那么自动化的程度便不够高,则需要调整提升自动化的效率。因此编程语言的选择与编程范式的形成便十分重要。则简而言之,问题转换后,需要执行与求解,因此需要将自然语言的描述性问题转换为计算机语言,可以使问题充分得到解决,此为自动化的过程。

综上,则计算思维的任务便为抽象、自动化与分析。

计算机思维的逻辑基础是什么? & 计算思维的更多相关文章

  1. 计算思维(Computational Thinking)在少儿编程中的体现

    本文主要针对少儿编程从业人员及正在学习编程的学生家长 大家好,我是C大叔,国内早期的少儿编程从业人员.一直以来都是在做scratch,JavaScript,python以及信息学奥赛C++的讲师,教研 ...

  2. 计算思维(美国CMU周以真教授)

    博主注:GIScience会议是国际上最为著名的地理信息系统领域的国际会议,自2000年起,每两年举办一次,GIScience 2008会议邀请了美国卡内基-梅隆大学(CMU)计算机系华裔教授周以真博 ...

  3. Python基础与科学计算常用方法

    Python基础与科学计算常用方法 本文使用的是Jupyter Notebook,Python3.你可以将代码直接复制到Jupyter Notebook中运行,以便更好的学习. 导入所需要的头文件 i ...

  4. python编程基础--计算机原理之硬件基础

    一.寄存器:寄存器是CPU内部用来存放数据的一些小型存储区域,用来暂时存放参与运算的数据和运算结果. 1.寄存器的特性: 1)寄存器位于CPU内部,数量很少,仅十四个: 2)寄存器所能存储的数据不一定 ...

  5. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 十八║Vue基础: 指令(下)+计算属性+watch

    回顾 今天来晚辣,给公司做了一个小项目,一个瀑布流+动态视频控制的DEMO,有需要的可以联系我,公司的项目就不对外展示了(一个后端程序员真的要干前端了哈哈哈). 书接上文,昨天正式的开始了Vue的代码 ...

  6. 思维分析逻辑 1 DAY

    数据分析原则:坚决不做提数机器. 数据分析工作模块 日报 了解业务现状 提升数据敏感性 数据波动解释 周报 了解数据的短期趋势 版本迭代分析 为结论型报告背书 月报 梳理业务的流程 为决策提供部分建议 ...

  7. Vue基础进阶 之 计算属性的使用

    计算属性的基本使用 初始小示例: 代码: window.onload = () =>{ new Vue({ el:'div', data:{ msg:'' } }) } </script& ...

  8. 从头学起Verilog(二):时序逻辑基础与回顾

    引言 时序逻辑对于数字电路设计十分重要,本文针对数字电路中的时序逻辑部分进行了系统的回顾. 存储器件 由于时序逻辑的输出不但受当前输入影响,还受之前的输入的影响,所以需要有存储单元对以前的输入进行存储 ...

  9. Codeforces 1220D 思维 数学 二分图基础

    原题链接 题意 我们有一个含多个正整数的集合B,然后我们将所有的整数,也就是Z集合内所有元素,都当做顶点 两个整数 \(i , j\) 能建立无向边,当且仅当 \(|i - j|\) 这个数属于B集合 ...

随机推荐

  1. 吴裕雄--天生自然python机器学习:使用朴素贝叶斯过滤垃圾邮件

    使用朴素贝叶斯解决一些现实生活中 的问题时,需要先从文本内容得到字符串列表,然后生成词向量. 准备数据:切分文本 测试算法:使用朴素贝叶斯进行交叉验证 文件解析及完整的垃圾邮件测试函数 def cre ...

  2. Momentum(动量)方法的python实现

    Momentum方法可以说是对SGD的进一步优化,细节可以参考这里 这里用python对其进行简单实现,如下: # coding=utf-8 """ 基于小批量梯度下降来 ...

  3. Django+Ajax+Mysql实现数据库数据的展示

    最近老师让搞一个系统,仅仅展示一下数据库的数据 在做海底捞时,是交接的师兄的项目,用的语言是java,框架是SSM(Spring.SpringMVC.MyBatis),这次我准备用Python写,前端 ...

  4. 基于Python的Flask基础知识

    Flask简介 Flask 是一个使用 Python 编写的轻量级 Web 应用程序框架.Armin Ronacher带领一个名为Pocco的国际Python爱好者团队开发了Flask. 下面我们简单 ...

  5. FPGA的存储方式大全

    好的时序是通过该严密的逻辑来实现的.http://blog.csdn.net/i13919135998/article/details/52117053介绍的非常好 有RAM(随机存储器可读可写)RO ...

  6. [LC] 81. Search in Rotated Sorted Array II

    Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. (i.e. ...

  7. 微软研究员Eric Horvitz解读 “人工智能百年研究”

    本文翻译自ScienceInsider"A 100-year study of artificial intelligence? Microsoft Research's Eric Horv ...

  8. MAYA卸载/完美解决安装失败/如何彻底卸载清除干净MAYA各种残留注册表和文件的方法

    在卸载MAYA重装MAYA时发现安装失败,提示是已安装或安装失败.这是因为上一次卸载后没有清理干净,系统会误认为已经安装过了.有的同学是新装的系统也会出现安装失败的情况,这是因为C++ 或者.NET的 ...

  9. 吴裕雄--天生自然 R语言开发学习:基本统计分析

    #---------------------------------------------------------------------# # R in Action (2nd ed): Chap ...

  10. 吴裕雄--天生自然 R语言开发学习:处理缺失数据的高级方法(续一)

    #-----------------------------------# # R in Action (2nd ed): Chapter 18 # # Advanced methods for mi ...