C语言入门到精通全教程课件.ppt
《C语言入门到精通全教程课件.ppt》由会员分享,可在线阅读,更多相关《C语言入门到精通全教程课件.ppt(435页珍藏版)》请在三一办公上搜索。
1、C语言程序设计Copyer:Vigiking,第一章 计算机语言与C语言概述,1.1 计算机语言概念 计算机语言定义 计算机能够识别和接受的语言。要使计算机按自己的意图工作,必须使用计算机所能接受、理解和执行的指令指挥计算机工作。,计算机语言的种类 机器语言 低级语言 汇编语言(面向计算机)BASIC 入门语言 F77 科学计算 高级语言 Foxpro 数据库管理(面向问题)C 多用途,计算机语言,机器语言 最早问世,用二进制代码构成指令。如:100000(+)110000(-)用机器语言编程的缺点:繁琐、不直观、不易调试。如计算y=2x2+3x-1需要七八条指令。移植性差。依赖于计算机。,汇
2、编语言 用符号构成指令,如:MOV、ADD 用汇编语言编程:相对直观,但仍繁琐,仍是面向计算机的语言。汇编语言是计算机间接接受的语言,高级语言与低级语言相比,有根本性的区别:是面向问题的语言。高级语言的一条指令(语句):y=2*x*x+3*x-1;对应于:y=2x2+3x-1 y=sin(x);对应于:y=sinx用高级语言编程:直观、易懂、移植性好(不依赖于具体计算机),上机运行高级语言程序需经过编译:编译 执行 要上机完成一个计算问题,主要的任务就是用高级语言编写出相应的源程序。即至少要学会一种计算机语言。,高级语言源程序,机器指令目的程序,结果,编译程序,1.2 C语言的特点 集高级语言
3、和低级语言的优点于一身:能实现低级语言的大部分功能(如直接访问内存物理地址、进行位操作等)。图形功能强。运算符和数据结构丰富。语法限制不太严格,程序设计自由度大。生成目标代码质量高,程序执行效率高。,1.3 简单的C程序介绍 例1:main()主函数说明 程序框架 printf(“abcdef”);函数体 语句 程序的功能是输出字符串:abcdef,例2:求两数之和。main()int a,b,c;a a=100;b=50;b c=a+b;c printf(“n c=%d”,c);程序运行结果:c=150,例3:求两数中的最大值。函数类型 函数名 形参main()int max(int x,i
4、nt y)int a,b,c;int z;scanf(“%d,%d”,a x b y c z(两个函数组成),3,5,3,5,5,5,总结上例可知:(1)C程序由函数构成。(2)函数由两部分组成:函数说明部分:函数名、函数类型、形参名、形参类型。函数体:实现函数的具体操作;由语句构成。(3)程序总是从main函数开始执行。(4)书写格式自由。(5)语句必须有分号。:,第二章 算法 2.1 算法的概念 要利用计算机处理问题,光学习语言的语法规则还不够,最重要的是要学会针对各类型的问题,拟定出有效的解题方法和步骤。解题方法和步骤就是算法。,算法:为了解决一个问题而采取的有限步骤。计算机算法:如何使
5、计算机一步一步地工作的具体过程。,利用计算机处理问题的步骤:1)设计好算法算法设计;2)用计算机语言实现算法程序设计。算法必须是“有效”的。算法设计还要充分考虑算法的好坏。衡量算法好坏的主要标准:程序简练。执行速度快。占空间少。,例:考虑 的算法。算法:直接表达。直接用语句 s=1+2+3+4+5+6+7+8+9+10,当项数较多时该算法不适用,s=i,1,10,算法:迭代法(累加求和法)s=1+2+3+4+5+6+7+8+9+10 算法步骤:s i 使s=0+使i=1 累加器 记数器 s+is i+1i 若i10转,否则转 输出s,0,1,1,2,3,3,6,4,10,5,该算法通用,是好算
6、法,2.2 算法的表示 算法需要有统一的表示方法 常用的表示方法有:自然语言 流程图 结构化流程图 N-S流程图.,1、自然语言 对于计算 s=1+2+3+4+5+6+7+8+9+10 用自然语言表示为:使s=0(s为累加器)使i=1(i为计数器)s+is(累加求和公式)i+1i(计数器加1)若i10转,否则转 输出s的值 特点:通俗易懂、文字冗长、含义不大严格。,2、流程图 用流程图符号表示算法。常用的流程图符号 起止框 输入输出框 处理框 流程线 判断框,对于计算 s=1+2+3+4+5+6+7+8+9+10 用流程图表示为:,s+i s,i+1 i,S+i s,S+i s,i10,输出s
7、,0 s,1 i,直观形象,易于理解,次序清楚,Y,N,3、结构化流程图 传统的流程图有一个弊端:对流程线没有严格的限制,对于较复杂的算法可能会变成乱麻一般(BS型算法)。为克服这一弊端,提出了由三个基本结构组成算法流程图的思想:结构化流程图,三个基本结构:顺序结构 按固定顺序(从上到下或从左到右)执行的结构。,A,B,a,b,选择结构 根据条件P选择执行哪一个分支。成立 不成立,p,A,B,a,b,成立,不成立,例:计算 y=1/x 当x0时 y=10000 当x=0时 的算法流程图图:选择结构,输入x,X=0?,10000y,1/xy,输出y,Y,N,循环结构 重复执行某些操作的结构。分为
8、两种:当型循环和直到型循环。当型循环 直到型循环,P1,A,A,P2,a,a,b,b,Y,Y,N,N,可以看出,每个基本结构都只有一个入口和一个出口,因此,用三个基本结构构成的流程图不会象乱麻一般,用三个基本结构构成的流程图就成为结构化流程图,用结构化流程图描述的算法称为结构化算法,相应的程序设计就称为结构化程序设计。,观察前例:,0 s,1 i,S+i s,i+1 i,i10,输出s,顺序结构,循环结构,y,n,4 N-S流程图N-S流程图的三个基本结构:,A,B,P,成立,不成立,A,B,A,B,当P1,直到P2,顺序结构,选择结构,循环结构,例:计算 y=1/x 当x0时 y=10000
9、 当x=0时 的N-S流程图:,输入x,X=0?,是,否,10000y 1/xy,输出y,例:计算 s=1+2+3+4+5+6+7+8+9+10 的N-S流程图:i10 直到i10 直到型 当型,0 s,1 i,输出s,1 i,0 s,s+i s,i+1 i,s+i s,i+1 i,输出s,第三章 数据类型、运算符 与 表达式 3.1 C 的数据类型基本类型(整型、实型、字符型、枚举型)构造类型(略)指针类型(略)空类型 各类型包含常量与变量,3.2 常量与变量 常量与符号常量 常量 在程序运行过程中其值保持不变的量。符号常量 用来代表一个常量的标识符。#define PI 3.1415926
10、,例:#define PI 3.1415926 main()float r=2,c;c=2*PI*r;printf(“%f”,c);,变量 其值可以改变的量。变量的三要素:变量名每个变量有一个名字,作为识别该变量的标识符。变量的值 每个变量有一个值,变量的值是随时可以改变的。,变量的存储单元 每个变量占据一个内存单元,用于存放变量的值。变量名 a 变量值 存储单元,3,变量的命名规则:由字母、数字和下划线组成 以字母或下划线开头 a、x1、y_2、_b1、_1c 合法 1x、a+2、不合法 变量必须先定义后使用。程序中何时使用常量?何时使用变量?,3.3 整型数据 整型常量 即整常数,c的整常
11、数有三种形式:十进制整数 与数学中的整数一致,如:100,123,15等。八进制整数 以0开头的整数,如:010,07,020等。十六进制整数 以0 x开头的整数,如:0 x10,0 xff,0 x2a等。,整型变量 用于存放整数的变量。分4种类型:基本型:int a 16位,可表示的数值范围:-3276832767 短整型:short int b 16位,可表示的数值范围:-3276832767 长整型:long int c 32位,数值范围:-21474836482147483647,无符号型:加上 unsigned 只存放正数。如:unsigned int x 变量x为无符号整数,16位
12、全表示数码,数值范围:065535 在程序设计中,如果要使用整型变量,必须首先选择以上类型符来定义变量,然后才能使用;,例:main()定义 int a,b,c;a=100;b=50;使用 c=a+b;printf(“%d”,c);一般根据什么原则选择变量的类型?,3.4 实型数据 实型常量 可使用两种形式表示:小数形式:如 1.23,3.1415926 15.48 指数形式:如 1e-20 1.23e5,实型变量 用于存放实数的变量 分单精度和双精度两种:float a,b 定义a和b为单精度型变量 32位,7位有效数字,10-381038 double x,y 定义x和y为双精度型变量 6
13、4位,15位有效数字,10-30810308,例:main()float r,c;double r,c;r=5;c=2*3.1415926*r;printf(“%f”,c);,3.5 字符型数据 字符常量 用单引号括起来的一个字符。a,x,*,1等 除此外,以开头的字符如n,t等 称为转义字符,祥见书表3.3,字符型变量 用于存放字符的变量。char c1,c2 定义c1和c2为字符型变量 c1=a;c2=b;字符赋值 字符型变量存放一个字符,占据一个字节,字符型数据的存储形式 存放ASCII码 不是 而是 如字符a在内存中存放97,b 存放98。与整数的存储形式一致,它们之间可以通用 一个字
14、符数据既可以作字符用,也可以作整数用(取其ASCII代码)。如:32+a相当于 32+97 若 int x;char c;则 x=a;c=97;x=97;c=a;都允许,a,97,字符串常量 用双引号括起来的字符序列。如:”abcde”,”china”a”也属字符串。注意”a”与a的区别。对于:char c;c=”a”;用法错误,字符串中每个字符各占一个字节,并且在字符串结尾加上一个结束标记0 如:”china”在内存中占6个字节。c h i n a 0 C语言中专门的字符串变量,可用字符数组存放(以后介绍)。,3.6 变量赋初值 在定义变量的同时给相应的变量赋初值。如:int a=3;a f
15、loat b=5.2;char c=a;int x=y=z=6;效果:在给变量分配内存单元的同时在相应的单 元中存放初值。,3,3.7 各数值型数据间的混合运算 整型、实型、字符型数据间可以进行混合运算,如:10-a*1.5 运算时,参加运算的两个数据如果类型不同,则首先将其类型转换成一致再运算,转换规则是:将优先级低的类型转换到优先级高的类型,数据类型的优先级:高 double float long unsignde 低 int char,3.8 算术运算符与算术表达式 基本的算术运算符+-*/%算术表达式 用算术运算符将运算对象连接起来的式子 用于表达数学公式的式子 如:2*x+y-1/a
16、 表达式经过运算最终得到一个值:算术表达式的值,运算符的优先级与结合性 优先级:在对表达式求值时,如果存在多个运算符,则运算的先后次序按运算符的优先级别从高到底进行。运算符的优先级关系为:高:*/%低:+-如:a-2*x 先算*2*(a+2)有括号的情况?,结合性:如果在一个运算对象两边的运算符的优先级相同,则按规定的“结合方向”处理。如:a-b+c b与-结合是从左到右,称“左结合性”。b与+结合是从右到左,称“右结合性”。每个运算符都有相应的优先级和结合性。基本算术运算符都是左结合性。,计算表达式例:2+A-1/2.0 1+3/2-1构造表达式例 2x2+3x-1,a+b a-b,a+b
17、a-b x+y x-y,a+b/a-b?,(a+b)/(a-b),2*x*x+3*x-1(*不能省),(a+b)/(a-b)/(x+y)/(x-y),(a+b)/(a-b)/(x+y)/(x-y),(a+b)/(a-b)/(x+y)*(x-y),强制类型转换可以用强制类型转换运算符将一个表达式的值转换成所需类型:如:(int)(x+y)(float)(7%3),应用举例:int a=200,b=300,c;c=a*b/100;?可知,有自动转换和强制转换,当自动转换达不到目的时,可用强制转换。,c=(long)a*b/100;,c=(long)(a*b)/100;,自增、自减运算符 自增运算符
18、:+使变量值加1 自减运算符:-使变量值减1 两种用法:+i,-i 先加(减)后用 i+,i-先用后加(减)两种用法对i效果一样,但表达式的值不同。例:假设i的原值为5:j=+i;j=?j=i+;j=?,注意:+和-只能用于变量。如:3+和(a+1)+不合法+和-为右结合性。(-i)+-i+-(i+)若i的原值是5,则该表达式的值是多少?,例:分析执行下列语句后的结果:a=5;a b c d b=a+;c=-a-b+;d=(a+)-(+b)+c-;,5,5,6,5,0,6,7,-2,6,-1,两种特殊情况:k=(i+)+(i+)+(i+)i+j 是 i+(+j)还是(i+)+j?i+虽然与i=
19、i+1等效,但使用自增自减运算符的代码优化程度好,因而经常使用;但用时需特别小心。,3.9 赋值运算符和赋值表达式 赋值运算符“=”称赋值运算符,其作用是将一个数据赋给一个变量。如:a=5 不要理解为“等号”。执行赋值运算的结果,是将右边的数据存入左边变量所对应的内存单元中。,赋值规则 如果赋值运算符两侧的类型不一致,则在赋值时要进行类型转换,转换规则为:实型整变量 舍去小数部分。int a=5.5;a中为5。整型实变量 数值不变,以浮点形式存储。字符型整变量 放在整形变量低8位。保持原值不变原则。int a=A;,复合赋值运算符 在赋值运算符前加上其它运算符,可以构成复合赋值运算符。a+=3
20、 a=a+3 b-=x+5 b=b-(x+5)x*=c-6 x=x*(c-6)y/=a*4 y=y/(a*4)k%=b-2 k=k%(b-2)属于高效率运算符。,赋值表达式 主要实现赋值运算的表达式。一般形式:=如:a=5 y=2*x+3 a=a+1 不是衡等作用:将右边表达式的值赋给左边的变量。赋值表达式的值取左边变量的值。,赋值表达式右边的可以是任何表达式,如:a=(b=5)赋值表达式中包含赋值表达式 赋值运算符的优先级低于所有算术运算符,且是右结合性。a=(b=5)与 a=b=5 等效。,例:计算以下表达式的值:a=b=c=5 a=5+(c=6)a=(b=4)+(c=6)a=(b=4.5
21、)+(c=6.5)(a、b、c为整型变量)a+=a-=a*a(设a的原值为3),赋值表达式是C语言中的一个重要成分,在赋值表达式后加一分号就成为常用的赋值语句。如 y=2*x+1;赋值表达式作为表达式的一种,可以出现在任何表达式中,如:x+2-(b/3-(a=k-5)+b,3.10 逗号表达式 逗号也是一种运算符,用它对两个表达式实现连接运算。3+5,6+8 称逗号表达式。逗号表达式的一般形式:表达式1,表达式2 取表达式2的值作为整个逗号表达式的值。如:a=3*5,a*4 逗号表达式的值为:60,一个逗号表达式又可以与另一个表达式组成一个新的逗号表达式,如:(a=3*5,a*4),a+5 因
22、此,逗号表达式的一般形式可以扩展为:表达式1,表达式2,表达式3,,表达式n 取表达式n的值作为整个逗号表达式的值。逗号运算符的优先级最低,且是左结合性。逗号运算符只起到连接作用,没有实际操作。,第四章 最简单的C程序设计,C 程序最基本的成分是语句 目前我们已掌握的语句:变量说明语句:int a,b,c;表达式语句:x+y;特别地:a=5;赋值语句,可以编写简单程序如:main()int x,y;x=5;y=2*x*x+3*x-1;该程序语法上完整,但还缺少输出。,数据的输出 用输出函数实现,其中的两种输出函数:1.putchar 函数(字符输出函数)用于输出一个字符。如:putchar(a
23、);putchar(100);char c=b;putchar(c);,例:输出单词Boy的完整程序:#include“stdio.h”注意该语句的作用 main()char a,b,c;a=B;b=o;c=y;putchar(a);putchar(b);putchar(c);,2.printf函数(格式输出函数)任意类型、任意格式、任意个数。例如:int a=100,b=56;printf(“a=%d,b=%d”,a,b);普通字符 格式说明 格式控制 输出表列 输出结果:a=100,b=56“%”后的字符称格式字符,不同格式字符对应不同的数据类型。,d格式符:按整数格式输出 几种用法:%d
24、 不指定宽度,按实际宽度输出%md 按指定宽度输出,m为宽度%ld 用于输出长整型数,例:int a=125,b=453;long c=65535;printf(“a=%d,b=%5d,c=%ld”,a,b,c);输出结果:a=125,b=453,c=65535,%ld也可以按指定宽度输出:printf(“c=%8ld”,c);输出结果:c=65535注意:格式字符的类型要与对应的输出对象的类型一致。,c格式符:用于输出字符 char c=A;printf(“c=%c,%c”,c,B);输出结果:c=A,B 输出对象既可以是字符变量、字符常量,还可以是整型表达式。,如:int a=100;ch
25、ar b=A;printf(“n%d,%c”,a,a);printf(“n%c,%d”,b,b);输出结果:100,d A,65,s格式符:用于输出字符串%s 不指定宽度%-ms 指定宽度,左靠齐%ms 指定宽度,右靠齐%m.ns 指定宽度m,只取左端n个字符,右靠齐%-m.ns 指定宽度m,只取左端n个字符,左靠齐,例:printf(“1:%s”,”abcd”);printf(“2:%8s”,”abcd”);printf(“3:%-8s”,”abcd”);printf(“4:%8.3s”,”abcd”);printf(“5:%-8.3s”,”abcd”);1:abcd2:abcd3:abcd
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 入门 精通 教程 课件
链接地址:https://www.31ppt.com/p-3724273.html