2022年二级C公共基础知识总结 .docx
二级公共基础学问总结第一章 数据结构与算法1.1 算法算法:是指解题方案的精确而完整的描述;算法不等于程序,也不等运算机方法,程序的编制不行能优于算法的设计;算法的基本特点:是一组严谨地定义运算次序的规章,每一个规章都是有效的,是明确的, 此次序将在有限的次数下终止;特点包括:(1) )可行性;(2) )确定性,算法中每一步骤都必需有明确定义,不充许有模棱两可的说明,不答应有多义性;(3) )有穷性,算法必需能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义;(4) )拥有足够的情报;算法的基本要素:一是对数据对象的运算和操作;二是算法的掌握结构;指令系统:一个运算机系统能执行的全部指令的集合;基本运算包括:算术运算、规律运算、关系运算、数据传输;算法的掌握结构:次序结构、挑选结构、循环结构;算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法;算法复杂度:算法时间复杂度和算法空间复杂度;算法时间复杂度是指执行算法所需要的运算工作量; 算法空间复杂度是指执行这个算法所需要的内存空间;1.2 数据结构的基本基本概念数据结构讨论的三个方面:(1) )数据集合中各数据元素之间所固有的规律关系,即数据的规律结构;(2) )在对数据进行处理时,各数据元素在运算机中的储备关系,即数据的储备结构;(3) )对各种数据结构进行的运算;数据结构是指相互有关联的数据元素的集合;数据的规律结构包含:(1) )表示数据元素的信息;(2) )表示各数据元素之间的前后件关系;数据的储备结构有次序、链接、索引等;线性结构条件:(1) )有且只有一个根结点;(2) )每一个结点最多有一个前件,也最多有一个后件;非线性结构:不满意线性结构条件的数据结构;1 3 线性表及其次序储备结构线性表是由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的;在复杂线性表中, 由如干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文件;非空线性表的结构特点:(1) )且只有一个根结点a1,它无前件;(2) )有且只有一个终端结点an ,它无后件;(3) )除根结点与终端结点外,其他全部结点有且只有一个前件,也有且只有一个后件;结点个数 n 称为线性表的长度,当n=0 时,称为空表;线性表的次序储备结构具有以下两个基本特点:(1) )线性表中全部元素的所占的储备空间是连续的;(2) )线性表中各数据元素在储备空间中是按规律次序依次存放的;ai 的储备地址为: ADRai=ADRa1+i-1k,ADRa1 为第一个元素的地址, k 代表每个元素占的字节数;次序表的运算:插入、删除;1 4 栈和队列栈是限定在一端进行插入与删除的线性表,答应插入与删除的一端称为栈顶,不答应插入与删除的另一端称为栈底;栈依据 “先进后出 ”( FILO )或 “后进先出 ”( LIFO )组织数据,栈具有记忆作用;用top 表示栈顶位置,用bottom 表示栈底;栈的基本运算:( 1 )插入元素称为入栈运算;(2 )删除元素称为退栈运算;(3 )读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化;队列是指答应在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表;Rear 指针指向队尾, front 指针指向队头;队列是 “先进行出 ”( FIFO )或 “后进后出 ”( LILO )的线性表;队列运算包括( 1 )入队运算:从队尾插入一个元素;(2)退队运算:从队头删除一个元素;循环队列: s=0 表示队列空, s=1 且 front=rear表示队列满1 5 线性链表数据结构中的每一个结点对应于一个储备单元,这种储备单元称为储备结点,简称结点;结点由两部分组成:(1)用于储备数据元素值,称为数据域;(2)用于存放指针,称为指针域,用于指向前一个或后一个结点;在链式储备结构中, 储备数据结构的储备空间可以不连续,各数据结点的储备次序与数据元素之间的规律关系可以不一样,而数据元素之间的规律关系是由指针域来确定的;链式储备方式即可用于表示线性结构,也可用于表示非线性结构;线性链表, HEAD 称为头指针, HEAD=NULL (或 0)称为空表, 假如是两指针: 左指针(Llink ) 指向前件结点,右指针(Rlink )指向后件结点;线性链表的基本运算:查找、插入、删除;1 6 树与二叉树树是一种简洁的非线性结构,全部元素之间具有明显的层次特性;在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结点,简称树的根;每一个结点可以有多个后件,称为该结点的子结点;没有后件的结点称为叶子结点;在树结构中, 一个结点所拥有的后件的个数称为该结点的度,全部结点中最大的度称为树的度;树的最大层次称为树的深度;二叉树的特点:( 1)非空二叉树只有一个根结点;(2 )每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树;二叉树的基本性质:(1) )在二叉树的第 k 层上,最多有 2k- 1k 1个(2) )深度为 m 的二叉树最多有 2m-1 个结点;结点;(3) )度为 0 的结点(即叶子结点)总是比度为2 的结点多一个;(4) )具有 n 个结点的二叉树, 其深度至少为 log2n+1, 其中 log2n 表示取 log2n 的整数部分;(5) )具有 n 个结点的完全二叉树的深度为log2n+1 ;(6) )设完全二叉树共有n 个结点;假如从根结点开头,按层序(每一层从左到右)用自然数 1, 2,.n 给结点进行编号(k=1,2 .n ),有以下结论:如 k=1 ,就该结点为根结点,它没有父结点; 如 k>1 ,就该结点的父结点编号为INTk/2 ;如 2kn,就编号为 k 的结点的左子结点编号为2k ;否就该结点无左子结点(也无右子结点);如 2k+1n,就编号为 k 的结点的右子结点编号为2k+1 ;否就该结点无右子结点;满二叉树是指除最终一层外,每一层上的全部结点有两个子结点,就k 层上有 2k-1 个结点深度为 m 的满二叉树有2m-1 个结点;完全二叉树是指除最终一层外,每一层上的结点数均达到最大值,在最终一层上只缺少右边的如干结点;二叉树储备结构采纳链式储备结构,对于满二叉树与完全二叉树可以按层序进行次序储备;二叉树的遍历:(1) )前序遍历( DLR ),第一拜访根结点,然后遍历左子树,最终遍历右子树;(2) )中序遍历( LDR ),第一遍历左子树,然后拜访根结点,最终遍历右子树;(3) )后序遍历( LRD )第一遍历左子树,然后拜访遍历右子树,最终拜访根结点;1 7 查找技术次序查找的使用情形:(1 )线性表为无序表;(2)表采纳链式储备结构;二分法查找只适用于次序储备的有序表,对于长度为n 的有序线性表,最坏情形只需比较log2n 次;1. 8 排序技术排序是指将一个无序序列整理成按值非递减次序排列的有序序列;交换类排序法:( 1)冒泡排序法,需要比较的次数为nn-1/2; ( 2 )快速排序法;插入类排序法:( 1 )简洁插入排序法,最坏情形需要nn-1/2次比较;( 2)希尔排序法,最坏情形需要On1.5 次比较;挑选类排序法:( 1 )简洁挑选排序法 , 最坏情形需要nn-1/2次比较;( 2 )堆排序法,最坏情形需要 Onlog2n 次比较;其次章 程序设计基础2. 1 程序设计设计方法和风格如何形成良好的程序设计风格1、源程序文档化;2、数据说明的方法; 3、语句的结构;4、输入和输出;注释分序言性注释和功能性注释,语句结构清晰第一、效率其次;2 2 结构化程序设计结构化程序设计方法的四条原就是:1.自顶向下; 2.逐步求精; 3. 模块化; 4. 限制使用 goto语句;结构化程序的基本结构和特点:(1) )次序结构:一种简洁的程序设计,最基本、最常用的结构;(2) )挑选结构:又称分支结构,包括简洁挑选和多分支挑选结构,可依据条件,判定应当挑选哪一条分支来执行相应的语句序列;(3) )循环结构:可依据给定条件,判定是否需要重复执行某一相同程序段;2. 3 面对对象的程序设计面对对象的程序设计: 以 60 岁月末挪威奥斯陆高校和挪威运算机中心研制的SIMULA语言为标志;面对对象方法的优点:(1 )与人类习惯的思维方法一样;(2 )稳固性好;( 3 )可重用性好;(4 )易于开发大型软件产品;(5 )可爱护性好;对象是面对对象方法中最基本的概念,可以用来表示客观世界中的任何实体,对象是实体的抽象;面对对象的程序设计方法中的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,由一组表示其静态特点的属性和它可执行的一组操作组成;属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法或服务;对象的基本特点:(1 )标识惟一性;(2 )分类性;( 3)多态性;( 4)封装性;( 5)模块独立性好;类是指具有共同属性、 共同方法的对象的集合; 所以类是对象的抽象, 对象是对应类的一个实例;消息是一个实例与另一个实例之间传递的信息;消息的组成包括( 1)接收消息的对象的名称;(2 )消息标识符,也称消息名;(3)零个或多个参数;继承是指能够直接获得已有的性质和特点,而不必重复定义他们;继承分单继承和多重继承;单继承指一个类只答应有一个父类,多重继承指一个类答应有多个父类;多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现象第三章 软件工程基础3. 1 软件工程基本概念运算机软件是包括程序、数据及相关文档的完整集合;软件的特点包括:(1) )软件是一种规律实体;(2) )软件的生产与硬件不同,它没有明显的制作过程;(3) )软件在运行、使用期间不存在磨损、老化问题;(4) )软件的开发、运行对运算机系统具有依靠性,受运算机系统的限制,这导致了软件移植的问题;(5) )软件复杂性高,成本昂贵;(6) )软件开发涉及诸多的社会因素;软件按功能分为应用软件、系统软件、支撑软件(或工具软件);软件危机主要表现在成本、质量、生产率等问题;软件工程是应用于运算机软件的定义、开发和爱护的一整套方法、工具、文档、实践标准和工序;软件工程包括3 个要素:方法、工具和过程;软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4 种基本活动:(1 ) P 软件规格说明;(2 )D 软件开发;( 3 )C 软件确认;(4 ) A 软件演进;软件周期:软件产品从提出、实现、使用爱护到停止使用退役的过程;软件生命周期三个阶段:软件定义、软件开发、运行爱护,主要活动阶段是:(1 )可行性讨论与方案制定;(2 )需求分析;( 3)软件设计;( 4 )软件实现;( 5)软件测试;( 6 )运行和爱护;软件工程的目标和与原就:目标:在给定成本、进度的前提下,开发出具有有效性、牢靠性、可懂得性、可爱护性、可重用性、可适应性、可移植性、可追踪性和可互操作性且满意用户需求的产品;基本目标: 付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能按时完成开发,准时交付使用;基本原就:抽象、信息隐藏、模块化、局部化、确定性、一样性、完备性和可验证性;软件工程的理论和技术性讨论的内容主要包括:软件开发技术和软件工程治理;软件开发技术包括:软件开发方法学、开发过程、开发工具和软件工程环境; 软件工程治理包括:软件治理学、软件工程经济学、软件心理学等内容;软件治理学包括人员组织、进度支配、质量保证、配置治理、项目方案等;软件工程原就包括抽象、 信息隐藏、 模块化、 局部化、 确定性、 一样性、 完备性和可验证性;3 2 结构化分析方法结构化方法的核心和基础是结构化程序设计理论;需求分析方法有( 1)结构化需求分析方法;( 2 )面对对象的分析的方法;从需求分析建立的模型的特性来分:静态分析和动态分析;结构化分析方法的实质:着眼于数据流,自顶向下,逐层分解,建立系统的处理流程,以数据流图和数据字典为主要工具,建立系统的规律模型;结构化分析的常用工具(1 )数据流图;( 2)数据字典;( 3 )判定树; ( 4 )判定表;数据流图: 描述数据处理过程的工具,是需求懂得的规律模型的图形表示,它直接支持系统功能建模;数据字典:对全部与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得用户和系统分析员对于输入、输出、储备成分和中间运算结果有共同的懂得;判定树: 从问题定义的文字描述中分清哪些是判定的条件,哪些是判定的结论, 依据描述材料中的连接词找出判定条件之间的从属关系、并列关系、挑选关系,依据它们构造判定树;判定表: 与判定树相像, 当数据流图中的加工要依靠于多个规律条件的取值,即完成该加工的一组动作是由于某一组条件取值的组合而引发的,使用判定表描述比较相宜;数据字典是结构化分析的核心;软件需求规格说明书的特点:(1 )正确性;( 2)无岐义性;( 3)完整性;( 4 )可验证性;( 5)一样性;( 6 )可懂得性;( 7)可追踪性;3 3 结构化设计方法软件设计的基本目标是用比较抽象概括的方式确定目标系统如何完成预定的任务,软件设计是确定系统的物理模型;软件设计是开发阶段最重要的步骤,是将需求精确地转化为完整的软件产品或系统的唯独途径;从技术观点来看,软件设计包括软件结构设计、数据设计、接口设计、过程设计;结构设计:定义软件系统各主要部件之间的关系;数据设计:将分析时创建的模型转化为数据结构的定义;接口设计:描述软件内部、软件和协作系统之间以及软件与人之间如何通信;过程设计:把系统结构部件转换成软件的过程描述;从工程治理角度来看:概要设计和具体设计;软件设计的一般过程: 软件设计是一个迭代的过程;先进行高层次的结构设计;后进行低层次的过程设计;穿插进行数据设计和接口设计;衡量软件模块独立性使用耦合性和内聚性两个定性的度量标准;在程序结构中各模块的内聚性越强,就耦合性越弱;优秀软件应高内聚,低耦合;软件概要设计的基本任务是:(1 )设计软件系统结构;( 2 )数据结构及数据库设计;(3 )编写概要设计文档;( 4 )概要设计文档评审;模块用一个矩形表示,箭头表示模块间的调用关系;在结构图中仍可以用带注释的箭头表示模块调用过程中来回传递的信息;仍可用带实心圆的箭头表示传递的是掌握信息,空心圆箭心表示传递的是数据;结构图的基本形式:基本形式、次序形式、重复形式、挑选形式;结构图有四种模块类型:传入模块、传出模块、变换模块和和谐模块;典型的数据流类型有两种:变换型和事务型;变换型系统结构图由输入、中心变换、输出三部分组成;事务型数据流的特点是:接受一项事务, 依据事务处理的特点和性质,挑选分派一个适当的处理单元,然后给出结果;具体设计: 是为软件结构图中的每一个模块确定实现算法和局部数据结构,用某种选定的表达工具表示算法和数据结构的细节;常见的过程设计工具有: 图形工具 (程序流程图) 、表格工具 (判定表) 、语言工具 ( PDL );3 4 软件测试软件测试定义: 使用人工或自动手段来运行或测定某个系统的过程,其目的在于检验它是否满意规定的需求或是弄清预期结果与实际结果之间的差别;软件测试的目的:发觉错误而执行程序的过程;软件测试方法:静态测试和动态测试;静态测试包括代码检查、静态结构分析、 代码质量度量; 不实际运行软件, 主要通过人工进行;动态测试:是基本运算机的测试,主要包括白盒测试方法和黑盒测试方法;白盒测试: 在程序内部进行, 主要用于完成软件内部CAO 作的验证; 主要方法有规律掩盖、基本基路径测试;黑盒测试: 主要诊断功能不对或遗漏、界面错误、数据结构或外部数据库拜访错误、性能错误、初始化和终止条件错,用于软件确认;主要方法有等价类划分法、边界值分析法、错误估计法、因果图等;软件测试过程一般按4 个步骤进行:单元测试、集成测试、验收测试(确认测试)和系统测试;3. 5 程序的调试程序调试的任务是诊断和改正程序中的错误,主要在开发阶段进行;程序调试的基本步骤:(1 )错误定位;( 2)修改设计和代码,以排除错误;(3)进行回来测试,防止引进新的错误;软件调试可分表静态调试和动态调试;静态调试主要是指通过人的思维来分析源程序代码和排错,是主要的设计手段,而动态调试是帮助静态调试;主要调试方法有:(1 )强行排错法;(2 )回溯法;( 3)缘由排除法;第四章 数据库设计基础4. 1 数据库系统的基本概念数据:实际上就是描述事物的符号记录;数据的特点:有肯定的结构,有型与值之分,如整型、实型、字符型等;而数据的值给出了符合定型的值,如整型值15;数据库: 是数据的集合, 具有统一的结构形式并存放于统一的储备介质内,是多种应用数据的集成,并可被各个应用程序共享;数据库存放数据是按数据所供应的数据模式存放的,具有集成与共享的特点;数据库治理系统:一种系统软件,负责数据库中的数据组织、数据操纵、数据爱护、掌握及爱护和数据服务等,是数据库的核心;数据库治理系统功能:(1) )数据模式定义:即为数据库构建其数据框架;(2) )数据存取的物理构建:为数据模式的物理存取与构建供应有效的存取方法与手段;(3) )数据操纵:为用户使用数据库的数据供应便利,如查询、插入、修改、删除等以及简洁的算术运算及统计;(4) )数据的完整性、安生性定义与检查;(5)数据库的并发掌握与故障复原;(6 )数据的服务:如拷贝、转存、重组、性能监测、分析等;为完成以上六个功能,数据库治理系统供应以下的数据语言:(1) )数据定义语言:负责数据的模式定义与数据的物理存取构建;(2) )数据操纵语言:负责数据的操纵,如查询与增、删、改等;(3) )数据掌握语言:负责数据完整性、安全性的定义与检查以及并发掌握、故障复原等;数据语言按其使用方式具有两种结构形式:交互式命令又称自含型或自主型语言宿主型语言(一般可嵌入某些宿主语言中);数据库治理员:对数据库进行规划、设计、爱护、监视等的专业治理人员;数据库系统:由数据库(数据)、数据库治理系统(软件)、数据库治理员(人员)、硬件平台(硬件)、软件平台(软件)五个部分构成的运行实体;数据库应用系统:由数据库系统、应用软件及应用界面三者组成;文件系统阶段:供应了简洁的数据共享与数据治理才能,但是它无法供应完整的、统一的、治理和数据共享的才能;层次数据库与网状数据库系统阶段:为统一与共享数据供应了有力支撑;关系数据库系统阶段数据库系统的基本特点:数据的集成性、数据的高共享性与低冗余性、数据独立性 (物理独立性与规律独立性)、数据统一治理与掌握;数据库系统的三级模式:(1) )概念模式:数据库系统中全局数据规律结构的描述,全体用户公共数据视图;(2) )外模式: 也称子模式与用户模式; 是用户的数据视图,也就是用户所见到的数据模式;(3) )内模式:又称物理模式,它给出了数据库物理储备结构与物理存取方法;数据库系统的两级映射:(1 )概念模式到内模式的映射;(2)外模式到概念模式的映射;4.2 数据模型数据模型的概念: 是数据特点的抽象, 从抽象层次上描述了系统的静态特点、 动态行为和约束条件, 为数据库系统的信息表与操作供应一个抽象的框架; 描述了数据结构、 数据操作及数据约束;E-R 模型的基本概念(1 )实体:现实世界中的事物;(2)属性:事物的特性;(3 )联系:现实世界中事物间的关系;实体集的关系有一对一、一对多、多对多的联系;E-R 模型三个基本概念之间的联接关系:实体是概念世界中的基本单位,属性有属性域, 每个实体可取属性域内的值;一个实体的全部属性值叫元组;E-R 模型的图示法:(1)实体集表示法;( 2 )属性表法;( 3)联系表示法;层次模型的基本结构是树形结构,具有以下特点:(1) )每棵树有且仅有一个无双亲结点,称为根;(2) )树中除根外全部结点有且仅有一个双亲;从图论上看,网状模型是一个不加任何条件限制的无向图;关系模型采纳二维表来表示,简称表, 由表框架及表的元组组成; 一个二维表就是一个关系;在二维表中凡能唯独标识元组的最小属性称为键或码;从全部侯选健中选取一个作为用户使 用的键称主键;表A 中的某属性是某表B 的键,就称该属性集为A 的外键或外码;关系中的数据约束:(1 )实体完整性约束:约束关系的主键中属性值不能为空值;(2)参照完全性约束:是关系之间的基本约束;(3 )用户定义的完整性约束:它反映了具体应用中数据的语义要求;4.3 关系代数关系数据库系统的特点之一是它建立在数据理论的基础之上,有许多数据理论可以表示关系模型的数据操作,其中最为闻名的是关系代数与关系演算;关系模型的基本运算:(1 )插入 ( 2 )删除 3 修改 (4 )查询(包括投影、挑选、笛卡尔积运算)4.4 数据库设计与治理数据库设计是数据应用的核心;数据库设计的两种方法:(1 )面对数据:以信息需求为主,兼顾处理需求;(2 )面对过程:以处理需求为主,兼顾信息需求;数据库的生命周期:需求分析阶段、概念设计阶段、规律设计阶段、物理设计阶段、编码阶段、测试阶段、运行阶段、进一步修改阶段;需求分析常用结构析方法和面对对象的方法;结构化分析(简称SA )方法用自顶向下、逐层分解的方式分析系统;用数据流图表达数据和处理过程的关系;对数据库设计来讲, 数据字典是进行具体的数据收集和数据分析所获得的主要结果;数据字典是各类数据描述的集合,包括5 个部分:数据项、数据结构、数据流(可以是数据项,也可以是数据结构)、数据储备、处理过程;数据库概念设计的目的是分析数据内在语义关系;设计的方法有两种(1 )集中式模式设计法(适用于小型或并不复杂的单位或部门);(2 )视图集成设计法;设计方法: E-R 模型与视图集成;视图设计一般有三种设计次序:自顶向下、由底向上、由内向外;视图集成的几种冲突:命名冲突、概念冲突、域冲突、约束冲突;关系视图设计:关系视图的设计又称外模式设计;关系视图的主要作用:(1 )供应数据规律独立性;(2)能适应用户对数据的不同需求;(3)有肯定数据保密功能;数据库的物理设计主要目标是对数据内部物理结构作调整并挑选合理的存取路径,以提高数据库拜访速度有效利用储备空间;一般RDBMS中留给用户参加物理设计的内容大致有索引设计、集成簇设计和分区设计;数据库治理的内容:(1 ) 数据库的建立;(2)数据库的调整;( 3 )数据库的重组;( 4)数据库安全性与完整性掌握;( 5 )数据库的故障复原;(6)数据库监控;附:历年考题20XX 年 9 月全国运算机等级考试二级笔试试卷1)以下数据结构中,属于非线性结构的是A)循环队列 B 带链队列C 二叉树D)带链栈2)以下数据结果中,能够依据“先进后出”原就存取数据的是A 循环队列B 栈 C队列D 二叉树3)对于循环队列,以下表达中正确选项A)队头指针是固定不变的B)队头指针肯定大于队尾指针C)队头指针肯定小于队尾指针D)队头指针可以大于队尾指针,也可以小于队尾指针4)算法的空间复杂度是指A)算法在执行过程中所需要的运算机储备空间B)算法所处理的数据量C)算法程序中的语句或指令条数D)算法在执行过程中所需要的暂时工作单元数5)软件设计中划分模块的一个准就是A 低内聚低耦合B 高内聚低耦合C 低内聚高耦合D 高内聚高耦合6)以下选项中不属于结构化程序设计原就的是A 可封装B 自顶向下C 模块化D 逐步求精7)软件具体设计产生的图如下: 该图是A N-S 图 B PAD 图 C 程序流程图D E-R 图8) 数据库治理系统是A)操作系统的一部分B 在操作系统支持下的系统软件C 一种编译系统D 一种操作系统9) 在 E-R 图中,用来表示实体联系的图形是A 椭圆图 B 矩形 C 菱形 D 三角形10) 有三个关系 R, S 和 T 如下:其中关系 T 由关系 R 和 S 通过某种操作得到,该操作为A选择B 投影C 交D 并11) 以下表达中正确选项A)程序设计的任务就是编写程序代码并上机B) )程序设计的任务就是确定所用数据结构C) 程序设计的任务就是确定所用算法D)以上三种说法都不完整 12)以下选项中,能用作用户标识符的是A) void B)8_8 C)_0_ D)unsigned13)阅读以下程序#include <stdio.h> main int case; float printF;printf请“输入 2 个数: ” ;scanf “ %d %f” ,&case,&pjrintF;pri ntf“ %d %n”f,case,printF;该程序编译时产生错误,其出错缘由是A)定义语句出错, case是关键字,不能用作用户自定义标识符B)定义语句出错, printF 不能用作用户自定义标识符C)定义语句无错, scanf 不能作为输入函数使用D)定义语句无错, printf 不能输出 case的值14)表达式: intdouble9/2-9%2的值是A) 0B)3C) 4D) 515) 如有定义语句: int x=10; ,就表达式 x-=x+x 的值为A) -20B )-10C) 0D) 1016) 有以下程序#include <stdio.h> main int a=1,b=0;printf“ %d,” ,b=a+b; printf“ %n”d ,a=2*b;程序运行后的输出结果是A) 0,0B) 1,0C) 3,2D) 1,217) 设有定义: int a=1,b=2,c=3; ,以下语句中执行成效与其它三个不同的是A)ifa>b c=a,a=b,b=c;B)ifa>b c=a,a=b,b=c;C)ifa>b c=a;a=b;b=c;D)ifa>b c=a;a=b;b=c; 18)有以下程序#include <stdio.h> main int c=0,k;for k=1;k<3;k+ switch kdefault: c+=kcase 2: c+;break;case 4: c+=2;break;printf“n” ,c;程序运行后的输出结果是A )3B)5C)7D) 9 19)以下程序段中,与语句:k=a>b.b>c.1:0:0 ;功能相同的是A) ifa>b&&b>c k=1;else k=0;B)ifa>b|b>c k=1;else k=0;C)ifa<=b k=0;else ifb<=c k=1; D) ifa>b k=1;else ifb>c k=1; else k=0; 20)有以下程序#include <stdio.h> main char s=“ 012xy ” ;int i,n=0; fori=0;si.=0;i+ifsi>= a &&si<= z n+; printf“ %n”d ,n;程序运行后的输出结果是A)0B) 2C) 3D) 5 21)有以下程序#include <stdio.h> main int n=2,k=0; whilek+&&n+>2; printf“ %d n%”d ,k,n;程序运行后的输出结果是A )0 2B) 1 3C)5 7D) 1 222)有以下定义语句,编译时会显现编译错误选项A) char a= aB ) char a= n; C) char a= aa;D )char a= 23)有以下程序#include <stdio.h> main char c1,c2; c1= A +-84;c2= A +-85;printf“ %c,%n”d ,c1,c2;x2d;已知字母 A 的 ASCII 码为 65,程序运行后的输出结果是A )E,68B)D,69C)E,DD)输出无定值24) 有以下程序#include <stdio.h> void funint p int d=2;p=d+; printf“ %d” ,p; main int a=1;funa; printfn“”%,ad; 程序运行后的输出结果是A) 32B)12C) 21D)2225) 以下函数 findmax 拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致不能实现预定功能#define MIN -2147483647int findmax int x,int n int i,max; fori=0;i<n;i+ max=MIN;ifmax<xi max=xi; return max;造成错误的缘由是A)定义语句 int i,max; 中 max 未赋初值B)赋值语句 max=MIN; 中,不应给 max 赋 MIN 值C)语句 ifmax<xi max=xi;中判定条件设置错D)赋值语句 max=MIN; 放错了位置(26)有以下程序#include <stdio.h> main int m=1,n=2,*p=&m,*q=&n,*r;r=p;p=q;q=r;printf“ %d,%d,%d,%n”d ,m,n,*p,*q;程序运行后的输出结果是A) 1,2,1,B) 1,2,2,1C) 2,1,2,D)2,1,1,227) 如有定义语句: int a410,*p,*q4;且 0 i<4,就错误的赋值是A) p=aB)qi=aiC)p=aiD)p=&a2128) 有以下程序#include <stdio.h> #include<string.h> main char str 20=“ One*World ” , “ One*Dream. ” ,*p=str1;printf“ %d,” ,strlenp;printf n” ,p;程序运行后的输出结果是“ %sA) 9,One*WorldB) 9,One*DreamC)10,One*DreamD) 10,One*World 29)有以下程序#include <stdio.h>main int a =2,3,5,4,i;fori=0;i<4;i+ switchi%2 case 0:switchai%2case 0:ai+;break; case 1:ai-;break;case 1:ai=0;fori=0;i<4;i + printf“ %d” ,ai; prinntf” ;“A )3 3 4 4B) 2 0 5 0C) 3 0 4 0D)0 3 0 430) 有以下程序#include <stdio.h> #include<string.h> main char a10=” abcd ”;print f “ %d,%nd” ,strlena,sizeofa;程序运行后的输出结果是A) 7,4B)4,10C) 8,8D)10,1031) 下面是有关C 语言字符数组的描述,其中错误选项A)不行以用赋值语句给字符数组名赋字符串B)可以用输入语句把字符串整体输入给字符数组C)字符数组中的内容不肯定是字符串D)字符数组只能存放字符串 32)以下函数的功能是funchar * a,char * b while*b=*a.=0 a+,b+; A)将 a 所指字符串赋给 b 所指空间B)使指针 b 指向 a 所指字符串 C)将 a 所指字符串和 b 所指字符串进行比较D)检查 a 和 b 所指字符串中是否有033)设有以下函数void funint n,char * s 就下面对函数指针的定义和赋值均是正确选项A)void *pf; pf=fun;B)viod *pf; pf=fun;C)void *pf; *pf=fun;D)void *pfint,char;pf=&fun;(34)有以下程序#include <stdio.h> int fint n;main int a=3,s;s=fa;s=s+fa;printfint fint n static int a=1; n+=a+;return n;n”“,s%; d程序运行以后的输出结果是A )7B)8C) 9D) 10 35)有以下程序#include <stdio.h> #define fx x*x*x main int a=3,s,t;s=fa+1;t=fa+1;prin