全套课件·C语言程序设计1.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《全套课件·C语言程序设计1.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 全套 课件 语言程序设计
- 资源描述:
-
1、第1章 程序设计基础大学计算机基础2主要内容1.1 程序设计语言的发展1.2 算法与程序设计1.3 C语言简介1.4 C语言的结构与执行1.5 C语言的运行与调试大学计算机基础3教学目的和基本要求:教学目的和基本要求:要求学生了解程序语言及算法的概念,C语言特点,C程序开发过程,简单C程序结构。教学重点:教学重点:算法的概念、C程序开发过程、简单C程序结构。大学计算机基础41.1 程序设计语言的发展 机器语言:计算机可以直接识别、执行的二进制代码。其优点是执行速度快;但难写、难读、难理解和难修改。汇编语言:使用助记符来代替机器语言中复杂、繁琐的指令的语言。如Z-80机中加法指令为ADD。其特点
2、是过分依赖于机器码,即仅适合某类相同或相似的计算机,因此不易移植。大学计算机基础51.1 程序设计语言的发展 高级语言:独立于计算机硬件结构,让用户使用面向问题的形式,更加方便编程人员的语言。高级语言分为如下两类 (1)编译型:“先编译后执行”,过程为:源代码-目标代码-机器代码,其执行与源程序相互独立。比如PASCAL,C等。(2)解释型:“边解释边运行”,程序执行离不开源代码的支持,不利于源程序的保护和保密。比如BASIC,FoxBASE+等。大学计算机基础61.1 程序设计语言的发展 面向结构(面向过程)的设计语言有:BASIC,FORTRAN,COBOL:面向事务处理的高级语言,适合于
3、编写管理信息系统方面的程序有:PASCAL,C语言,PROLOG,FoxBASE+等 面向对象和可视化语言:C+,Java,Visual BASIC,Visual C+,Visual Foxpro,Visual J+,Delphi,PowerBuilder等。网页(Web)/网络(Network)编程语言:HTML,DHTML,JavaScript/Jscript,VBScript,JavaApplet,Java等。大学计算机基础71.2 算法与程序设计算法及其表示算法及其表示 2 结构化程序设计结构化程序设计与面向对象程序设计与面向对象程序设计大学计算机基础81.2.1、算法及其表示 算法是
4、计算机科学中的重要概念之一,它指明了问题的计算过程,是对给定问题解题方案的准确而完整的描述。计算机没有软件的支持将无法工作,软件是计算机的灵魂,而软件的核心是算法。用计算机解决问题的方法和步骤就是算法,计算机执行算法,用计算机解决各种数据处理问题的主要方式就是寻找和设计各种算法,将算法变成代码的过程即程序设计。算法及其表示1大学计算机基础91.2.1、算法及其表示 算法具备如下5个特征:有穷性 确定性 输入 输出 可行性算法特征2大学计算机基础101.2.1、算法及其表示 算法可以用多种方法描述,常见的表示方法有:自然语言描述法、伪代码表示法、传统流程图表示法、N-S流程图表示法等。【例例1-
5、1】已经杯A中盛放的是油,杯B中盛放的是水,另有一个空杯C,三个杯容积相同,请用自然语言表示算法。【解答解答】第1步:将A中的油全部倒入C中,使A成为空杯;第2步:将B中的水全部倒入A中,使B成为空杯;第3步:将C中原在A中的油,倒入B中,完成A与B中液体 的交换。算法的表示算法的表示3大学计算机基础111.2.1、算法及其表示符号符号名称含义起止框开始和结束 输入/输出框输入/输出操作 处理框 内容进行处理 判断框条件进行判断 流程线流程的方向 连接点 使流程图清晰(1)使用传统流程图表示算法)使用传统流程图表示算法 大学计算机基础12真给a 和b赋值a、?、等;转义字符:n、t、v、b、r
6、、f、0、”、ddd、xhh等。大学计算机基础432.2.2 标识符的分类 标识符可分如下几类:关键字亦称保留字,关键字在C语言中有特定的含义,用户在使用自定义的常量名、变量名、函数名、类型名、文件名时,要绝对避免使用关键字,C语言中的保留字32个,保留字用小写字母表示,大写的可以由用户自由使用,尽量不用,以免与系统保留字混淆.关键字关键字1大学计算机基础442.2 标识符描述数据类型定义的有:typedef、void;描述存储类型的有:auto、extern、register、static、volatile;描述数据类型的有:char、int、float、double、long、short、
7、signed、struct、union、unsigned、const、enum;描述语句:break、case、continue、default、if、else、switch、for、do、while、return、sizeof、goto。大学计算机基础452.2 标识符 预定义标识符包括C语言中提供的一些库函数的名字(如printf,scanf,getchar,putchar等)和编译预处理命令(define include等),建议用户在自定义常、变量时,也要避免与这些标识符冲突。用户在程序设计过程中,会经常用到常量、变量、自定义函数、文件名、类型名等,这些要用户定义。预定义标识符预定义标
8、识符2用户定义标识符用户定义标识符3大学计算机基础462.2 标识符下面给出一些合法的标识符:sum,average,_total,temp,a_1,char1,Max,min下面这些是不合法的标识符:1a,$total,a,a.next 在使用标识符的时候尽量采取“见名识义、常用从简”的原则,保证变量具有可读性,又不要让变量名过长。大学计算机基础47常量常量 程序执行过程中,其值不能被改变的量称为常量,C语言中出现的常量有如下类型:整型常量、实型常量、字符常量、字符串常量等。2.3 常量大学计算机基础482.3 常量常量整型常量整型常量 实型常量实型常量 字符常量字符常量 字符串常量字符串常
9、量 符号常量与预处理简介符号常量与预处理简介 大学计算机基础492.3.1 整型常量2.3.1 整型常量整型常量整型常量在C语言中又分:十进制整数 八进制整数 十六进制整数 十进制整数以人们通常习惯的十进制整数形式给出.八进制整数必须以0开头,其数码取值范围为07.以下是合法的八进制数:012(对应十进制整数10),-012(对应十进制数-10),0177777(对应十进制数65535),0177777(对应十进制数-65535)。十进制整数十进制整数1八进制整数八进制整数2大学计算机基础502.3 常量以下是不合法的八进制整数:255(无前缀0),03A2(包含非法数码)【例例2-1】输出八
10、进制数。#include/*在在visual C+6.0 下调试通过下调试通过*/main()int x,y;x=012;y=-0177777;printf(x=%d,y=%dn,x,y);大学计算机基础512.3 常量 十六进制整数的前缀为十六进制整数的前缀为0 x或或0X,其数码取值范,其数码取值范围为围为09,AF,af。以下是合法的十六进制整数:0X12(十进制数18),-0 x12(十进制数-18),0XA1,0Xffff(十进制数为65535)以下各数不是合法的十六进制整数:6B(无前缀0 x),0 x5H(含有非法数码H)在整型数据的后边加上后缀“L”或“l”(小写字母l)来表示
11、的该数据是一个长整型的数据。例如:589L十进制012L八进制 0X17L十六进制 十六进制整数十六进制整数3大学计算机基础522.3.2 实型常量 实型常量也称为浮点型。有两种形式:十进制小数形式和指数形式。十进制小数形式:由数码09和小数点组成。如下均为合法的实数:0.12,1.23,-2.5145,125.0指数形式:,由十进制数,加上阶码标志“e”或“E”及阶码(只能为整数,可以带符号)组成。如:指数值如:指数值1.2E6等于1.21065.21E-2等于5.2110-20.91E8等于0.91108-1.8E-9等于-1.810-9大学计算机基础532.3.3 字符常量 字符常量是用
12、西文半角单引号括起来的一个字符。在C语言中,字符常量有以下特点:(1)字符常量只能用单引号“”括起来,不能用双引号或括号。(2)字符常量只能是单个字符,不能是字符串。(3)字符可以是字符集中任意字符,但数字被定义为字符型之后就不能参与数值运算。大学计算机基础542.3.3 字符常量 除了以上形式的字符常量外,C语言还允许使用一种特殊形式的字符常量,即转义字符,它以一个反斜线“”开头,后跟一个或几个字符的字符序列。转义字符转义字符 转义字符转义字符的意义的意义 ASCII代码代码 n 换行换行 10t水平制表水平制表 9b退格退格 8r回车回车 13f换页换页 12反斜线符反斜线符 92单引号符
13、单引号符 39”双引号符双引号符 34ddd13位八进位八进制数制数xhh12位十六位十六进制数进制数大学计算机基础552.3.3 字符常量【例例2-2】输出转义字符。【程序分析与解答程序分析与解答】#include /*visual C+6.0*/main()printf(abctderftgn);printf(1234567812345678n);/*参照物*/printf(htibbjk);printf(1234567812345678n);/*参照物*/输出结果为:fgde1234567812345678hjk1234567812345678Press any key to conti
14、nue大学计算机基础562.3.4 字符串常量 字符串常量是由一对双引号括起的字符序列。例如,“211 Project”,“Chinese”,“college”等都是合法的字符串常量。字符串常量和字符常量的数据结构不同,其主要区别如下:(1)字符常量由单引号括起来,字符串常量由双引号 括起来;(2)字符常量只能是单个字符,字符串常量含一个或多个字符。大学计算机基础572.3.4 字符串常量C在内存中占一个字节,表示为:“C”在内存中占两个字节,表示为:可以把一个字符常量赋予一个字符变量,但是不能把一个字符串常量赋予一个字符量。字符串常量占的内存字节数等于字符串半角字符数加1,因为在增加的一个字
15、节中存放字符“0”(ASCII码值为0),这是字符串结束的标志。CC0大学计算机基础582.3.5 符号常量与预处理 在C语言中,可以用一个标识符来表示一个常量,称为符号常量。符号常量在使用之前必须先定义,其一般形式为:#define 标识符标识符 常量常量 其中,#include也是一条预处理命令(预处理命令都以“#”开头),称为宏定义命令,其功能是把该标识符定义为常量。一经定义,以后程序中所有的标识符都代表该常量,如果要修改这个常量,可以实现整个程序中“一改全改”。经常将符号常量的标识符用大写字母,变量标识符用小写字母,以示区别。大学计算机基础592.4 变量变量整型变量整型变量 实型变量
16、实型变量 字符变量字符变量 大学计算机基础60 变量是指在程序执行过程中可以被改变和赋值的量。程序中每一个变量有一个符合C语言标识符规范的名称,在内存中占据一定的存储单元。变量的使用方法是先声明(定义变量),后使用。变量名与变量值是有区别的,变量的“名”是指变量所代表的存储单元的标志,而“值”是指存储单元的内容.例:2.4 变量A _变量 变量值3大学计算机基础612.4.1 整型变量 如:short int x;/*变量的声明,定义整型变量*/x=10;/*变量赋值*/0000000000001010 变量x在内存中的地址是0 x0013ff70 数据在内存中的二进制存储示意图(1)基本型:
17、类型说明符为int,在内存中占4个字节。(2)短整型:类型说明符为short int或short,占2个字节。(3)长整型:类型说明符为long int或long,4个字节。(4)无符号型:类型说明符为unsigned,。无符号型又可与上述三种类型匹配而构成,不能表示负数:整型数据在内存中的存储形式整型数据在内存中的存储形式 1整型变量的分类整型变量的分类2大学计算机基础622.4.1 整型变量【例例2-3】测试当前C编译环境下数据类型占用的字节数。【程序分析与解答程序分析与解答】#include main()printf(“int占%d字节。n”,sizeof(int);printf(“lo
18、ng int占%d字节。n”,sizeof(long int);printf(“short int占%d字节。n”,sizeof(short int);printf(“unsigned int占%d字节。n”,sizeof(unsigned int);printf(“unsigned long int占%d字节。n”,sizeof(unsigned long int);printf(“unsigned short int占%d字节。n”,sizeof(unsigned short int);输出结果为:int占4字节。long int占4字节。short int占2字节。unsigned in
19、t占4字节。unsigned long int占4字节。unsigned short int占2字节。大学计算机基础632.4.1 整型变量变量定义的一般形式为:类型说明符 变量名标识符1,变量名标识符2,;例如:int x,y,z;/*x,y,z为整型变量*/long int n,m;/*n,m为长整型变量,long int 可简写为long*/unsigned int a,b;/*a,b为无符号整型变量,unsigned int 可简写为unsigned*/注意:(1)允许在一次定义相同 类型的多个变量(2)最后一个变量名之 后必须以分号结尾。整型变量的定义整型变量的定义3大学计算机基础6
20、42.4.2 实型变量 实型数据一般占用4个字节(32位)的内存空间,按指数形式存储。例如,实数12.345在内存中的存储形式如图2-4所示:图2-4 实型数据的表示 +/-,用0,1表示(数符)0.12345 +/-,用0,1表示(阶符)2实型数据在内存中的存放形式实型数据在内存中的存放形式1大学计算机基础652.4.2 实型变量 实型变量分为单精度(float型),长单精度型(long float),双精度(double型)和长双精度(long double型)4类,其中float型占用4个字节,其它数据类型均占用8个字节。由于实型变量由有限的存储单元组成,因此能提供的数字是有限的,而在有
21、效位以外的数字将被舍去。这样可能会产生一些误差,例如,a+20的显然就应该比a大。请分析下面的程序。实型变量数据的分类实型变量数据的分类 2实型数据的舍入误差实型数据的舍入误差3大学计算机基础662.4.2 实型变量【例2-4】实型数据的舍入误差。【程序分析与解答】#include main()float a,b;a=123456.789e5;/*12345678900*/b=a+20;printf(%fn,b);输出结果为:12345678868.000000大学计算机基础672.4.3 字符变量 字符变量用来存储字符常量,其说明符是char.字符变量的赋值有如下方式:(1)若ch_a是一个
22、字符变量,ch=ch_a;(2)将字符常量a赋值给ch,ch=a;(3)将某个字符的ASCII码赋给ch,ch=65,则ch的内 容为A,但由于整型变量在存储上均超过1个字节,如果将一个整型变量赋值给一个字符变量时,只会将其最低8个位赋值给ch。而ch=A则是错误的.如下字符变量的输出形式:(1)printf(%c,ch);(2)printf(%d,ch);(3)putchar(ch);大学计算机基础682.5 数据间的混合运算各数据类型转换规则各数据类型转换规则 自动类型转换与强制转换自动类型转换与强制转换 大学计算机基础69 不同数据类型转换规则不同数据类型转换规则 整型、单精度型、双精度
23、型数据可以混合运算。字符型数据可以与整型通用,因此,整型、实型(包括单、双精度)、字符型数据间可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算。转换的规则按图所示 2.5.1 各数据类型转换规则double float long unsigned int char,short大学计算机基础702.5.2 自动类型转换与强制转换 变量的数据类型的转换方法有两种,一种是自动转换,一种是强制转换。自动转换遵循以下规则:若参与运算量的类型不同,则先转换成同一类型,然后进行运算。转换按照数据长度增加的方向进行,以保证运算精度不降低。所有的浮点运算都是以双精度进行的。char型和
24、short型运算时,必须先转换成int型。赋值运算中,赋值号两边的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。自动类型转换自动类型转换1大学计算机基础712.5 数据间的混合运算其一般形式为:其一般形式为:(类型说明符)(表达式)例如:(float)a /*把a转换为实型*/(int)(x+y)/*把x+y的结果转换为整型*/无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。强制转换强制转换 2大学计算机基础722.5.2 自动类型转换与强制转换【例例2-5】数据类型的强制转换。【程序分析与解答程序分析与解
25、答】#include main()float f=5.75;printf(int)f=%d,f=%fn,(int)f,f);输出结果为:(int)f=5,f=5.750000大学计算机基础73变量预先设置初值可以有如下几种情况:变量预先设置初值可以有如下几种情况:(1)对各变量分别赋初值 int a=3;float pi=3.14159;char cha;(2)定义变量时对部分变量赋值 int a,b,c=5;(3)对几个变量赋相同的初值 如:若对几个变量赋予初值3,应写成 int a=3,b=3,c3;2.6 变量赋初值大学计算机基础742.6 变量赋初值强制类型转换运算符强制类型转换运算符
展开阅读全文