Coursera课程笔记----计算导论与C语言基础----Week 1
计算机的基本原理(Week 1)
第一次数学危机
公元前500年,毕达哥拉斯学派,他们相信数是万物的本源:一切数均可表示成整数或者整数之比
然而毕达哥拉斯证明了勾股定理,某些直角三角形的三边比不能用整数表达
希帕索斯悖论:边长为1的正方形,对角线?
危机的缓解:比例论,使用几何方法避开无理数
危机的解决:实数理论的建立
第二次数学危机
微积分:牛顿和莱布尼兹,建立在**无穷小****分析之上
贝克莱悖论:无穷小一会儿是0,一会儿不是0,像一个幽灵~
危机的缓解:重建实数理论
新的问题:魏尔斯特拉斯给出了一个处处不可微的连续函数➡直观&几何思考不可靠
第三次数学危机
集合论:康托尔建立,一切数学成果可建立在集合论基础上
罗素悖论:S由一切不是自身元素的集合所组成,S是否属于S?
哥德尔不完备性定理:把数学彻底形式化的愿望是不可实现的
问题:如何判断问题可计算or不可计算?
解决思路:为计算建立一个数学模型(计算模型),它能够完成的就是可计算的——图灵机
图灵与图灵机
1936年,《论可计算数在判定问题中的应用》提出了理想的计算机数学模型——图灵机(Turing Machine)
图灵机的构成
一条存储带:其上有一个个小方格,可存储一个数字or字母
一个控制器:包含一个读写头(读or写or改),可接受程序语句,可存储&改变自身状态,可沿着存储带移动
图灵机如何工作
准备:存储带初始化、控制器置于起始并设置好自身状态、准备好程序
执行过程:读字母or数字、根据状态和字符找到对应的程序语句、执行三个动作(写入字母or数字、变更自身状态、左右移)
停机:表示计算完毕,存储带上即为计算结果
图灵机的理论意义
特点:简单,强大,可实现
意义:可实现的通用计算模型,引入了通过读写符号和状态改变进行运算的思想,证实了基于简单字母表完成复杂运算的能力,引入了存储区、程序、控制器等概念的原型
计算机为什么能计算
计算机中数的表示——二进制
十进制转为二进制:除以二的商取余数,”触底反弹“
二进制转为八进制和十六进制:卡3位/4位
计算机中数的计算——布尔运算
基本逻辑运算:与、或、非
复合逻辑运算:同或、异或等
二进制加法:本位是异或运算,进位是与运算——半加器
半加器进行组合,一个半加器的输出作为另一个半加器的输入——全加器
布尔运算的实现——电路
结论——电路能够实现计算
Coursera课程笔记----计算导论与C语言基础----Week 1的更多相关文章
- Coursera课程笔记----计算导论与C语言基础----Week 6
理性认识C程序 导论(Week 6) 明确学习进度 讲课内容 感性➡️理性➡️函数➡️指针等 作业练习 初级阶段 ➡️正常作业练习 C语言的由来 程序设计语言的分类 低级语言之机器语言 0010101 ...
- Coursera课程笔记----计算导论与C语言基础----Week 8
C语言中的运算成分(Week 8) 赋值运算符 "="赋值运算符 给赋值号左边的变量赋予数值 在变量定义的同时可以为变量赋初值 要点一:两面类型不同 若=两边的类型不一致,赋值时要 ...
- Coursera课程笔记----计算导论与C语言基础----Week 7
C语言中的数据成分(Week7) 内存 把内存想象成长带,带子上有许多方格,每个方格有8位(8bit) 2^10 = 1024 1B = 8 b 1KB = 1024Byte MB.GB.TB.PB- ...
- Coursera课程笔记----计算导论与C语言基础----Week 4
感性认识计算机程序(Week 4) 引入 编程序 = 给计算机设计好运行步骤 程序 = 人们用来告诉计算机应该做什么的东西 问题➡️该告诉计算机什么?用什么形式告诉? 如果要创造一门"程序设 ...
- Coursera课程笔记----计算导论与C语言基础----Week 2
计算机的历史与未来(Week 2) 计算机历史 早期计算机:手工计算器➡️机械计算器➡️计算机原型 现代计算机:电子管计算机➡️晶体管计算机➡️集成电路计算机➡️超大规模集成电路 早期的手工计算辅助工 ...
- Coursera课程笔记----计算导论与C语言基础----Week 9
C语言中的控制成分(Week 9) 计算机程序的基本结构 任何具有单入口单出口的程序,都可以用顺序结构.分支结构.循环结构来表达 分支语句 在执行if语句前,先对表达式求解 if()内可以是任意的数值 ...
- Coursera课程笔记----计算导论与C语言基础----Week 3
存储程序式计算机 冯·诺伊曼式计算机 "关于EDVAC的报告草案" 组成:控制器(协调工作).运算器(算数&逻辑运算).存储器(存储操作信息和中间结果).输入设备.输出设备 ...
- Coursera课程笔记----计算导论与C语言基础----Week 12
期末编程测试(Week 12) Quiz1 判断闰年 #include <iostream> using namespace std; int main() { int year; cin ...
- Coursera课程笔记----计算导论与C语言基础----Week 11
C程序中的字符串(Week 11) 字符数组 所有的字符串,都是以\0结尾的 只能在数组定义并初始化的时候:char c[6] = "China"; 不能用赋值语句将一个字符串常量 ...
随机推荐
- 使用malloc和free函数进行内存动态分配
一.在学习c语言里面,内存分配这个话题非常有意思,因为我们平时在开发的时候,如果一不小心没注意内存释放的话,写的的程序很容易出错,所以今天就来回顾一下c语言里面的内存动态分配,下面我们先来看一个实例来 ...
- Linux/UNIX 下终端复用利器 tmux
简介 tmux 是一个终端复用器类自由软件,功能类似 GNU Screen,但使用 BSD 许可发布.用户可以通过 tmux 在一个终端内管理多个分离的会话,窗口及面板,对于同时使用多个命令行,或多个 ...
- python圆周率计算小程序(非常慢)
源码: from math import fabs #导入数学模块 from time import perf_counter #导入时间模块 from numba import jit @jit d ...
- NCTF2018_easy_audit->coding_breaks
easy_audit 题目源码 <?php highlight_file(__FILE__); error_reporting(0); if($_REQUEST){ foreach ($_REQ ...
- 微信小程序基本知识
逻辑实现 1 使用动态数据展示列表(可以考虑使用wx:for属性配合动态数组渲染全部列表项,以减少WXML页面的代码量) eg: <view class='listGroup' wx:for= ...
- Python推荐系统框架:RecQ
RecQ是一个用于推荐系统的python库(python2.7.x),实现了一些state-of-the-art的推荐算法. github地址:https://github.com/Coder-Yu/ ...
- System类的两个静态方法currentTimeMillis 和 arraycopy
package com.yhqtv.demo02.ThreadPool; import java.util.Arrays; public class Test { public static void ...
- python face_recognition模块实现人脸识别
import face_recognition #人脸识别库 pip cmake dlib import cv2 #读取图像 face_image1 = face_recognition.load_i ...
- [Abp vNext 入坑分享] - 前言
一·背景 Abp vnext是 ABP 框架作者所发起一个完全基于 ASP .NET Core框架,截至2020年4月份已经升级到2.5.0版本,根据经验2.0版本以后可以放心的使用在生产环境.类似a ...
- <vector>常用操作
如果不清楚vector是什么的话就去看我的另一篇随笔吧:https://www.cnblogs.com/buanxu/p/12791785.html 进入正题,vector和string一样,也是一种 ...