计算机二级公共基础知识(全)

1.1 算法 考点1 算法的基本概念 计算机解题的过程实际上是在实施某种算法,这种算法称为计算机算法。 算法(algorithm)是一组严谨地定义运算顺序的规则,并且每一个规则都是有效的,同时是明确的;此顺序将在有限的次数后终止。算法是对特定问题求解步骤的一种描述,它是指令的有限序列,其中每一条指令表示一个或多个操作。 1算法的基本特征 (1)可行性(effectiveness):针对实际问题而设计的算法,执行后能够得到满意的结果。 (2)确定性(definiteness):算法中的每一个步骤都必须有明确的定义,不允许有模棱两可的解释和多义性。 (3)有穷性(finiteness):算法必需在有限时间内做完,即算法必需能在执行有限个步骤之后终止。 (4)拥有足够的情报:要使算法有效必需为算法提供足够的情报当算法拥有足够的情报时,此算法才最有效的;而当提供的情报不够时,算法可能无效。 2算法的基本要素 (1)算法中对数据的运算和操作:每个算法实际上是按解题要求从环境能进行的所有操作中选择合适的操作所组成的一组指令序列。 计算机可以执行的基本操作是以指令的形式描述的。一个计算机系统能执行的所有指令的集合,称为该计算机系统的指令系统。计算机程序就是按解题要求从计算机指令系统中选择合适的指令所组成的指令序列在一般的计算机系统中,基本的运算和操作有以下4类: ①算术运算:主要包括加、减、乘、除等运算; ②逻辑运算:主要包括“与”、“或”、“非”等运算; ③关系运算:主要包括“大于”、“小于”、“等于”、“不等于”等运算; ④数据传输:主要包括赋值、输入、输出等操作。 (2)算法的控制结构:一个算法的功能不仅仅取决于所选用的操作,而且还与各操作之间的执行顺序有关。算法中各操作之间的执行顺序称为算法的控制结构。 算法的控制结构给出了算法的基本框架,它不仅决定了算法中各操作的执行顺序,而且也直接反映了算法的设计是否符合结构化原则。描述算法的工具通常有传统流程图、N-S结构化流程图、算法描述语言等。一个算法一般都可以用顺序、选择、循环3种基本控制结构组合而成。 (3)算法设计的基本方法 计算机算法不同于人工处理的方法,下面是工程上常用的几种算法设计,在实际应用时,各种方法之间往往存在着一定的联系。 (1)列举法 列举法是计算机算法中的一个基础算法。列举法的基本思想是,根据提出的问题,列举所有可能的情况,并用问题中给定的条件检验哪些是需要的,哪些是不需要的。 列举法的特点是算法比较简单。但当列举的可能情况较多时,执行列举算法的工作量将会很大。因此,在用列举法设计算法时,使方案优化,尽量减少运算工作量,是应该重点注意的。 (2)归纳法 归纳法的基本思想是,通过列举少量的特殊情况,经过分析,最后找出一般的关系。从本质上讲,归纳就是通过观察一些简单而特殊的情况,最后总结出一般性的结论。 (3)递推 递推是指从已知的初始条件出发,逐次推出所要求的各中间结果和最后结果。其中初始条件或是问题本身已经给定,或是通过对问题的分析与化简而确定。递推本质上也属于归纳法,工程上许多递推关系式实际上是通过对实际问题的分析与归纳而得到的,因此,递推关系式往往是归纳的结果。对于数值型的递推算法必须要注意数值计算的稳定性问题。 (4)递归 人们在解决一些复杂问题时,为了降低问题的复杂程度(如问题的规模等),一般总是将问题逐层分解,最后归结为一些最简单的问题。这种将问题逐层分解的过程,实际上并没有对问题进行求解,而只是当解决了最后那些最简单的问题后,再沿着原来分解的逆过程逐步进行综合,这就是递归的基本思想。 递归分为直接递归与间接递归两种。 (5)减半递推技术 实际问题的复杂程度往往与问题的规模有着密切的联系。因此,利用分治法解决这类实际问题是有效的。工程上常用的分治法是减半递推技术。 所谓“减半”,是指将问题的规模减半,而问题的性质不变;所谓“递推”,是指重复“减半”的过程。 (6)回溯法 在工程上,有些实际问题很难归纳出一组简单的递推公式或直观的求解步骤,并且也不能进行无限的列举。对于这类问题,一种有效的方法是“试”。通过对问题的分析,找出一个解决问题的线索,然后沿着这个线索逐步试探,若试探成功,就得到问题的解,若试探失败,就逐步回退,换别的路线再逐步试探。 4算法设计的要求 通常一个好的算法应达到如下目标: (l)正确性(correctness) 正确性大体可以分为以下4个层次: ①程序不含语法错误; ②程序对于几组输入数据能够得出满足规格说明要求的结果; ③程序对于精心选择的典型、苛刻而带有刁难性的几组输入数据能够得出满足规格说明要求的结果; ④程序对于一切合法的输入数据都能产生满足规格说明要求的结果。 (2)可读性(readability) 算法主要是为了方便入的阅读与交流,其次才是其执行。可读性好有助于用户对算法的理解;晦涩难懂的程序易于隐藏较多错误,难以调试和修改。 (3)健壮性(robustness) 当输入数据非法时,算法也能适当地做出反应或进行处理,而不会产生莫名其妙的输出结果。 (4)效率与低存储量需求 效率指的是程序执行时,对于同一个问题如果有多个算法可以解决,执行时间短的算法效率高;存储量需求指算法执行过程中所需要的最大存储空间 考点2 算法的复杂度 1算法的时间复杂度 算法的时间复杂度,是指执行算法所需要的计算工作量。同一个算法用不同的语言实现,或者用不同的编译程序进行编译,或者在不同的计算机上运行,效率均不同。这表明使用绝对的时间单位衡量算法的效率是不合适的。撇开这些与计算机硬件、软件有关的因素,可以认为一个特定算法“运行工作量”的大小,只依赖于问题的规模(通常用整数n表示),它是问题的规模函数。即 算法的工作量=f(n) 例如,在N×N矩阵相乘的算法中,整个算法的执行时间与该基本操作(乘法)重复执行的次数n3成正比,也就是时间复杂度为n3,即 f(n)=O(n3) 在有的情况下,算法中的基本操作重复执行的次数还随问题的输入数据集不同而不同。例如在起泡排序的算法中,当要排序的数组a初始序列为自小至大有序时,基本操作的执行次数为氏当初始序列为自大至小有序时,基本操作的执行次数为n(n- 1)/2。对这类算法的分析,可以采用以下两种方法来分析

计算机二级基础知识 文库,计算机二级公共基础知识(全)相关推荐

  1. 全国计算机等级考试二级教程——公共基础知识(2013年版)pdf,全国计算机等级考试2级教程:公共基础知识(2013年版)...

    <全国计算机等级考试2级教程:公共基础知识(2013年版)>是根据教育部考试中心颁布的<全国计算机等级考试二级公共基础知识考试大纲<2913年版)>的要求,在2012年版 ...

  2. 二级VB培训笔记08:公共基础知识

    二级VB培训笔记08:公共基础知识 一.公共基础思维导图

  3. 计算机二级基础知识 文库,计算机二级--公共基础知识(第1章)

    计算机二级--公共基础知识(第1章) (13页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 19.9 积分 第1章 数据结构与算法1.1 算法1.1.1 ...

  4. 公共基础知识和计算机相关知识了解农业常识,公共基础知识:农业为本

    原标题:公共基础知识:农业为本 从古至今,我们一直都在研究农业,关于农业的著作也是数不胜数,我们主要了解以下几部作品. 一.知识介绍 1.氾胜之--<氾胜之书> 西汉时期重要的农学著作,我 ...

  5. 计算机二级基础知识 文库,计算机二级选择题基础知识.docx

    计算机二级选择题基础知识.docx 11.第一台计算机1946年2月14日,在美国宾西尼亚大学的莫尔电机学院,世界第一台现代电子计算机"埃尼阿克"ENIAC诞生,重达30T,在1S ...

  6. 计算机公共基础知识病毒,大学生村官公共基础知识:计算机安全及病毒防治

    一.计算机病毒的分类: 计算机病毒根据分类标准不同,可以有不同的分类方法. 1.按破坏程度来分,可分为良性病毒和恶性病毒. 2.按攻击系统的类型来分,可以将计算机病毒分为DOS系统病毒.Windows ...

  7. 计算机基础知识点文库,计算机基础知识点汇总.doc

    计算机基础知识点汇总.doc (19页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 14.9 积分 一-.基础操作1. 在中文Windows中,使用软键 ...

  8. 华图教育计算机基础知识,公共基础知识备考:计算机辅助制造

    华图教育网整理了2019公共基础知识题库及答案.公共基础知识模拟题.公共基础知识练习题.公共基础知识复习资料等,希望帮助考生快速顺利的掌握2019公共基础知识考点. 一.计算机辅助制造的概述 计算机辅 ...

  9. 公岸网:公共基础知识必背内容

    1.马克思主义哲学原理:辩证唯物论.唯物辩证法.辩证唯物主义认识论.历史唯物主义. 2.毛泽东思想概论:毛泽东思想形成与发展.新民主主义革命理论.社会主义改造理论. 3.中国特色社会主义理论体系:邓小 ...

最新文章

  1. 事物的开始和结束命令分别是什么_AutoCAD小秘密065:LOFT命令,创建天圆地方
  2. dynamic web module消失不见
  3. 在python中可以使用urllib方便的实现图片和flash下载
  4. yii 引用php文件,Yii中引出php文件及插件
  5. Java基础学习总结(41)——JPA常用注解
  6. 关于ISA2006引起网速慢或间歇性断网的问题的解决方法
  7. 5绘制收银台程序_进来学知识了:实操之C/C++的绘制
  8. source insight 4 破解
  9. javaSE_06Java中的数组(array)-思维导图
  10. linux 去掉csv文件第一行,使用PowerShell删除文本文件的第一行
  11. Pytorch GAN实战 MINIST手写数字识别分布解析
  12. 解决github下载及访问不稳定问题
  13. C++程序设计语言练习4.2 茴字的几种写法
  14. 不良资产证券化之后,谁来买单?
  15. linux部署qq机器人记录
  16. 比林志玲cute的katee
  17. nginx-rtmp 的部署
  18. ffmpeg音乐+图片合成视频
  19. 免费全平台直播推流软件OBS Studio应用
  20. Python爬虫——下载音乐

热门文章

  1. mysql 类型解释_MySQL 数据类型说明解释
  2. window挂载到linux服务器上,Windows服务器目录挂载到linux服务器
  3. antd upload手动上传_Flask上传文件
  4. python取出字符串中的偶数_从给定字符串中删除偶数个连续的重复字符
  5. sublime text3使用教程python_Sublime Text 编辑器配置 Python解释器简易教程
  6. IDEA2021配置Tomcat
  7. arm oe linux gnueabi 系统,【技术分享】Quectel 4G模块Opencpu中实现高通wifi功能
  8. python sql注入脚本_python打造一个分析网站SQL注入的脚本
  9. esp32 rtc 时钟设置不对_STM32入门系列-STM32时钟系统,STM32时钟树
  10. apache 编译支持php_apache2 不支持php文件 解决办法(示例代码)