c语言程序编程心得.docx

上传人:b****1 文档编号:2571082 上传时间:2023-05-04 格式:DOCX 页数:45 大小:31.44KB
下载 相关 举报
c语言程序编程心得.docx_第1页
第1页 / 共45页
c语言程序编程心得.docx_第2页
第2页 / 共45页
c语言程序编程心得.docx_第3页
第3页 / 共45页
c语言程序编程心得.docx_第4页
第4页 / 共45页
c语言程序编程心得.docx_第5页
第5页 / 共45页
c语言程序编程心得.docx_第6页
第6页 / 共45页
c语言程序编程心得.docx_第7页
第7页 / 共45页
c语言程序编程心得.docx_第8页
第8页 / 共45页
c语言程序编程心得.docx_第9页
第9页 / 共45页
c语言程序编程心得.docx_第10页
第10页 / 共45页
c语言程序编程心得.docx_第11页
第11页 / 共45页
c语言程序编程心得.docx_第12页
第12页 / 共45页
c语言程序编程心得.docx_第13页
第13页 / 共45页
c语言程序编程心得.docx_第14页
第14页 / 共45页
c语言程序编程心得.docx_第15页
第15页 / 共45页
c语言程序编程心得.docx_第16页
第16页 / 共45页
c语言程序编程心得.docx_第17页
第17页 / 共45页
c语言程序编程心得.docx_第18页
第18页 / 共45页
c语言程序编程心得.docx_第19页
第19页 / 共45页
c语言程序编程心得.docx_第20页
第20页 / 共45页
亲,该文档总共45页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

c语言程序编程心得.docx

《c语言程序编程心得.docx》由会员分享,可在线阅读,更多相关《c语言程序编程心得.docx(45页珍藏版)》请在冰点文库上搜索。

c语言程序编程心得.docx

c语言程序编程心得

c语言程序编程心得

c语言程序设计

本课介绍c语言程序设计的基本方法和基本的程序语句。

从程序流程的角度来看,程序可以分为三种基本结构,即顺序结构、分支结构、循环结构。

这三种基本结构可以组成所有的各种复杂程序。

c语言提供了多种语句来实现这些程序结构。

本章介绍这些基本语句及其应用,使读者对c程序有一个初步的认识,为后面各章的学习打下基础。

c程序的语句

c程序的执行部分是由语句组成的。

程序的功能也是由执行语句实现的。

C语句可分为以下五类:

1.表达式语句

2.函数调用语句

3.控制语句

4.复合语句

5.空语句

1.表达式语句

表达式语句由表达式加上分号“;”组成。

其一般形式为:

表达式;执行表达式语句就是计算表达式的值。

例如:

x=y+z;赋值语句y+z;加法运算语句,但计算结果不能保留,无实际意义i++;自增1语句,i值增1

2.函数调用语句

由函数名、实际参数加上分号“;”组成。

其一般形式为:

函数名(实际参数表);执行函数语句就是调用函数体并把实际参数赋予函数定义中的形式参数,然后执行被调函数体中的语句,求取函数值。

(在第五章函数中再详细介绍)例如printf("CProgram");调用库函数,输出字符串。

3.控制语句

控制语句用于控制程序的流程,以实现程序的各种结构方式。

它们由特定的语句定义符组成。

c语言有九种控制语句。

可分成以下三类:

(1)条件判断语句

if语句,switch语句

(2)循环执行语句

dowhile语句,while语句,for语句

(3)转向语句

break语句,goto语句,continue语句,return语句

4.复合语句

把多个语句用括号{}括起来组成的一个语句称复合语句。

在程序中应把复合语句看成是单条语句,而不是多条语句,例如

{

x=y+z;

a=b+c;

printf(“%d%d”,x,a);

}

是一条复合语句。

复合语句内的各条语句都必须以分号“;”结尾,在括号“}”外不能加分号。

5.空语句

只有分号“;”组成的语句称为空语句。

空语句是什么也不执行的语句。

在程序中空语句可用来作空循环体。

例如while(getchar()!

=''''\n'''');本语句的功能是,只要从键盘输入的字符不是回车则重新输入。

这里的循环体为空语句。

赋值语句

赋值语句是由赋值表达式再加上分号构成的表达式语句。

其一般形式为:

变量=表达式;赋值语句的功能和特点都与赋值表达式相同。

它是程序中使用最多的语句之一。

在赋值语句的使用中需要注意以下几点:

1.由于在赋值符“=”右边的表达式也可以又是一个赋值表达式,因此,下述形式变量=(变量=表达式);是成立的,从而形成嵌套的情形。

其展开之后的一般形式为:

变量=变量=…=表达式;

例如:

a=b=c=d=e=5;按照赋值运算符的右接合性,因此实际上等效于:

e=5;

d=e;

c=d;

b=c;

a=b;

2.注意在变量说明中给变量赋初值和赋值语句的区别。

给变量赋初值是变量说明的一部分,赋初值后的变量与其后的其它同类变量之间仍必须用逗号间隔,而赋值语句则必须用分号结尾。

3.在变量说明中,不允许连续给多个变量赋初值。

如下述说明是错误的:

inta=b=c=5必须写为inta=5,b=5,c=5;而赋值语句允许连续赋值

4.注意赋值表达式和赋值语句的区别。

赋值表达式是一种表达式,它可以出现在任何允许表达式出现的地方,而赋值语句则不能。

下述语句是合法的:

if((x=y+5)>0)z=x;语句的功能是,若表达式x=y+5大于0则z=x。

下述语句是非法的:

if((x=y+5;)>0)z=x;因为=y+5;是语句,不能出现在表达式中。

数据输出语句

本小节介绍的是向标准输出设备显示器输出数据的语句。

在c语言中,所有的数据输入/输出都是由库函数完成的。

因此都是函数语句。

本小节先介绍printf函数和putchar函数。

printf函数printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。

其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。

在前面的例题中我们已多次使用过这个函数。

一、printf函数调用的一般形式

printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。

但作为一个特例,不要求在使用printf函数之前必须包含stdio.h文件。

printf函数调用的一般形式为:

printf(“格式控制字符串”,输出表列)其中格式控制字符串用于指定输出格式。

格式控制串可由格式字符串和非格式字符串两种组成。

格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。

如“%d”表示按十进制整型输出,“%ld”表示按十进制长整型输出,“%c”表示按字符型输出等。

后面将专门给予讨论。

非格式字符串在输出时原样照印,在显示中起提示作用。

输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。

voidmain()

{

inta=88,b=89;

printf("%d%d\n",a,b);

printf("%d,%d\n",a,b);

printf("%c,%c\n",a,b);

printf("a=%d,b=%d",a,b);

}

a<--8,b<--89

printf("%d%d\n",a,b);

printf("%d,%d\n",a,b);

printf("%c,%c\n",a,b);

printf("a=%d,b=%d",a,b);

本例中四次输出了a,b的值,但由于格式控制串不同,输出的结果也不相同。

第四行的输出语句格式控制串中,两格式串%d之间加了一个空格(非格式字符),所以输出的a,b值之间有一个空格。

第五行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的a,b值之间加了一个逗号。

第六行的格式串要求按字符型输出a,b值。

第七行中为了提示输出结果又增加了非格式字符串。

二、格式字符串

在TurboC中格式字符串的一般形式为:

[标志][输出最小宽度][.精度][长度]类型其中方括号[]中的项为可选项。

各项的意义介绍如下:

1.类型类型字符用以表示输出数据的类型,其格式符和意义下表所示:

表示输出类型的格式字符格式字符意义

d以十进制形式输出带符号整数(正数不输出符号)

o以八进制形式输出无符号整数(不输出前缀O)

x以十六进制形式输出无符号整数(不输出前缀OX)

u以十进制形式输出无符号整数

f以小数形式输出单、双精度实数

e以指数形式输出单、双精度实数

g以%f%e中较短的输出宽度输出单、双精度实数

c输出单个字符

s输出字符串

2.标志

标志字符为-、+、#、空格四种,其意义下表所示:

标志格式字符标志意义

-结果左对齐,右边填空格

+输出符号(正号或负号)空格输出值为正时冠以空格,为负时冠以负号

#对c,s,d,u类无影响;对o类,在输出时加前

缀o对x类,在输出时加前缀0x;对e,g,f类当结果有小数时才给出小数点

3.输出最小宽度

用十进制整数来表示输出的最少位数。

若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

4.精度

精度格式符以“.”开头,后跟十进制整数。

本项的意义是:

如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。

5.长度

长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出。

voidmain(){

inta=15;

floatb=138.3576278;

doublec=35648256.3645687;

chard=''''p'''';

printf("a=%d,%5d,%o,%x\n",a,a,a,a);

printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b);

printf("c=%lf,%f,%8.4lf\n",c,c,c);

printf("d=%c,%8c\n",d,d);

}a<--15

b<--138.3576278

c<--35648256.3645687

d<--''''p''''main()

{

inta=29;

floatb=1243.2341;

doublec=24212345.24232;

charc=''''h''''

printf("a=%d,%5d,%o,%x\n",a,a,a,a);

printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b);

printf("c=%lf,%f,%8.4lf\n",c,c,c);

printf("d=%c,%8c\n",d,d);

}

本例第七行中以四种格式输出整型变量a的值,其中“%5d”要求输出宽度为5,而a值为15只有两位故补三个空格。

第八行中以四种格式输出实型量b的值。

其中“%f”和“%lf”格式的输出相同,说明“l”符对“f”类型无影响。

“%5.4lf”指定输出宽度为5,精度为4,由于实际长度超过5故应该按实际位数输出,小数位数超过4位部分被截去。

第九行输出双精度实数,“%8.4lf”由于指定精度为4位故截去了超过4位的部分。

第十行输出字符量d,其中“%bc”指定输出宽度为8故在输出字符p之前补加7个空格。

使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。

不同的编译系统不一定相同,可以从左到右,也可从右到左。

TurboC是按从右到左进行的。

如把例2.13改写如下述形式:

voidmain(){

inti=8;

printf("%d\n%d\n%d\n%d\n%d\n%d\n",++i,--i,i--,i++,-i--);

}i<--8

这个程序与例2.13相比只是把多个printf语句改一个printf语句输出。

但从结果可以看出是不同的。

为什么结果会不同呢?

就是因为printf函数对输出表中各量求值的顺序是自右至左进行的。

在式中,先对最后一项“-i--”求值,结果为-8,然后i自减1后为7。

再对“-i++”项求值得-7,然后i自增1后为8。

再对“i--”项求值得8,然后i再自减1后为7。

再求“i++”项得7,然后I再自增1后为8。

再求“--i”项,i先自减1后输出,输出值为7。

最后才求输出表列中的第一项“++i”,此时i自增1后输出8。

但是必须注意,求值顺序虽是自右至左,但是输出顺序还是从左至右,因此得到的结果是上述输出结果。

字符输出函数

putchar函数

putchar函数是字符输出函数,其功能是在显示器上输出单个字符。

其一般形式为:

putchar(字符变量)例如:

putchar(''''A'''');输出大写字母A

putchar(x);输出字符变量x的值

putchar(''''\n'''');换行对控制字符则执行控制功能,不在屏幕上显示。

使用本函数前必须要用文件包含命令:

#include

#include

voidmain(){

chara=''''B'''',b=''''o'''',c=''''k'''';

putchar(a);putchar(b);putchar(b);putchar(c);putchar(''''\t'''');

putchar(a);putchar(b);

putchar(''''\n'''');

putchar(b);putchar(c);

}

数据输入语句

c语言的数据输入也是由函数语句完成的。

本节介绍从标准输入设备―键盘上输入数据的函数scanf和getchar。

scanf函数scanf函数称为格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。

一、scanf函数的一般形式

scanf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中,与printf函数相同,c语言也允许在使用scanf函数之前不必包含stdio.h文件。

scanf函数的一般形式为:

scanf(“格式控制字符串”,地址表列);其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。

地址表列中给出各变量的地址。

地址是由地址运算符“&”后跟变量名组成的。

例如,&a,&b分别表示变量a和变量b的地址。

这个地址就是编译系统在内存中给a,b变量分配的地址。

在c语言中,使用了地址这个概念,这是与其它语言不同的。

应该把变量的值和变量的地址这两个不同的概念区别开来。

变量的地址是C编译系统分配的,用户不必关心具体的地址是多少。

变量的地址和变量值的关系如下:

&a--->a567a为变量名,567是变量的值,&a是变量a的地址。

在赋值表达式中给变量赋值,如:

a=567在赋值号左边是变量名,不能写地址,而scanf函数在本质上也是给变量赋值,但要求写变量的地址,如&a。

这两者在形式上是不同的。

&是一个取地址运算符,&a是一个表达式,其功能是求变量的地址。

voidmain(){

inta,b,c;

printf("inputa,b,c\n");

scanf("%d%d%d",&a,&b,&c);

printf("a=%d,b=%d,c=%d",a,b,c);

}

注意&的用法!

在本例中,由于scanf函数本身不能显示提示串,故先用printf语句在屏幕上输出提示,请用户输入a、b、c的值。

执行scanf语句,则退出TC屏幕进入用户屏幕等待用户输入。

用户输入7、8、9后按下回车键,此时,系统又将返回TC屏幕。

在scanf语句的格式串中由于没有非格式字符在“%d%d%d”之间作输入时的间隔,因此在输入时要用一个以上的空格或回车键作为每两个输入数之间的间隔。

如:

789

7

8

9

格式字符串

格式字符串的一般形式为:

%[*][输入数据宽度][长度]类型其中有方括号[]的项为任选项。

各项的意义如下:

1.类型

表示输入数据的类型,其格式符和意义下表所示。

格式字符意义

d输入十进制整数

o输入八进制整数

x输入十六进制整数

u输入无符号十进制整数

f或e输入实型数(用小数形式或指数形式)

c输入单个字符

s输入字符串

2.“*”符

用以表示该输入项读入后不赋予相应的变量,即跳过该输入值。

如scanf("%d%*d%d",&a,&b);当输入为:

123时,把1赋予a,2被跳过,3赋予b。

3.宽度

用十进制整数指定输入的宽度(即字符数)。

例如:

scanf("%5d",&a);

输入:

12345678

只把12345赋予变量a,其余部分被截去。

又如:

scanf("%4d%4d",&a,&b);

输入:

12345678将把1234赋予a,而把5678赋予b。

4.长度

长度格式符为l和h,l表示输入长整型数据(如%ld)和双精度浮点数(如%lf)。

h表示输入短整型数据。

使用scanf函数还必须注意以下几点:

a.scanf函数中没有精度控制,如:

scanf("%5.2f",&a);是非法的。

不能企图用此语句输入小数为2位的实数。

b.scanf中要求给出变量地址,如给出变量名则会出错。

如scanf("%d",a);是非法的,应改为scnaf("%d",&a);才是合法的。

c.在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格,TAB或回车作间隔。

C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非法数据)时即认为该数据结束。

d.在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。

例如:

scanf("%c%c%c",&a,&b,&c);

输入为:

def

则把''''d''''赋予a,''''f''''赋予b,''''e''''赋予c。

只有当输入为:

def

时,才能把''''d''''赋于a,''''e''''赋予b,''''f''''赋予c。

如果在格式控制中加入空格作为间隔,如scanf("%c%c%c",&a,&b,&c);则输入时各数据之间可加空格。

voidmain(){

chara,b;

printf("inputcharactera,b\n");

scanf("%c%c",&a,&b);

printf("%c%c\n",a,b);

}

scanf("''''C14F14%c%c",&a,&b);

printf("%c%c\n",a,b);由于scanf函数"%c%c"中没有空格,输入MN,结果输出只有M。

而输入改为MN时则可输出MN两字符,见下面的输入运行情况:

inputcharactera,b

MN

MN

voidmain(){

chara,b;

printf("inputcharactera,b\n");

scanf("%c%c",&a,&b);

printf("\n%c%c\n",a,b);

}

scanf("%c%c",&a,&b);本例表示scanf格式控制串"%c%c"之间有空格时,输入的数据之间可以有空格间隔。

e.如果格式控制串中有非格式字符则输入时也要输入该非格式字符。

例如:

scanf("%d,%d,%d",&a,&b,&c);其中用非格式符“,”作间隔符,故输入时应为:

5,6,7

又如:

scanf("a=%d,b=%d,c=%d",&a,&b,&c);

则输入应为

a=5,b=6,c=7g.如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。

voidmain(){

inta;

printf("inputanumber\n");

scanf("%d",&a);

printf("%ld",a);

}

由于输入数据类型为整型,而输出语句的格式串中说明为长整型,因此输出结果和输入数据不符。

如改动程序如下:

voidmain(){

longa;

printf("inputalonginteger\n");

scanf("%ld",&a);

printf("%ld",a);

}

运行结果为:

inputalonginteger

1234567890

1234567890当输入数据改为长整型后,输入输出数据相等。

键盘输入函数

getchar函数getchar函数的功能是从键盘上输入一个字符。

其一般形式为:

getchar();通常把输入的字符赋予一个字符变量,构成赋值语句,如:

charc;

c=getchar();#include

voidmain(){

charc;

printf("inputacharacter\n");

c=getchar();

putchar(c);

}

使用getchar函数还应注意几个问题:

1.getchar函数只能接受单个字符,输入数字也按字符处理。

输入多于一个字符时,只接收第一个字符。

2.使用本函数前必须包含文件“stdio.h”。

3.在TC屏幕下运行含本函数程序时,将退出TC屏幕进入用户屏幕等待用户输入。

输入完毕再返回TC屏幕。

voidmain(){

chara,b,c;

printf("inputcharactera,b,c\n");

scanf("%c%c%c",&a,&b,&c);

printf("%d,%d,%d\n%c,%c,%c\n",a,b,c,a-32,b-32,c-32);

}

输入三个小写字母

输出其ASCII码和对应的大写字母。

voidmain(){

inta;

longb;

floatf;

doubled;

charc;

printf("%d,%d,%d,%d,%d",sizeof(a),sizeof(b),sizeof(f)

sizeof(d),sizeof(c));

}

输出各种数据类型的字节长度。

分支结构程序

关系运算符和表达式

在程序中经常需要比较两个量的大小关系,以决定程序下一步的工作。

比较两个量的运算符称为关系运算符。

在c语言中有以下关系运算符:

<小于

<=小于或等于

>大于

>=大于或等于

==等于

!

=不等于

关系运算符都是双目运算符,其结合性均为左结合。

关系运算符的优先级低于算术运算符,高于赋值运算符。

在六个关系运算符中,<,<=,>,>=的优先级相同,高于==和!

=,==和!

=的优先级相同。

关系表达式

关系表达式的一般形式为:

表达式关系运算符表达式例如:

a+b>c-d,x>3/2,''''a''''+1

由于表达式也可以又是关系表达式。

因此也允许出现嵌套的情况,例如:

a>(b>c),a!

=(c==d)等。

关系表达式的值是“真”和“假”,用“1”和“0”表示。

如:

5>0的值为“真”,即为1。

(a=3)>(b=5)由于3>5不成立,故其值为假,即为0。

voidmain(){

charc=''''k'''';

inti=1,j=2,k=3;

floatx=3e+5,y=0.85;

printf("%d,%d\n",''''a''''+5=k+1);

printf("%d,%d\n",1

printf("%d,%d\n",i+j+k==-2*j,k==j==i+5);

}

charc=''''k'''';

inti=1,j=2,k=3;

floatx=3e+5,y=0.85;

printf("%d,%d\n",''''a''''+5=k+1);

printf("%d,%d\n",1

printf("%d,%d\n",i+j+k==-2*j,k==j==i+5);

在本例中求出了各种关系运算符的值。

字符变量是以它对应的ASCII码参与运算的。

对于含多个关系运算符的表达式,如k==j==i+5,根据运算符的左结合性,先计算k==j,该式不成立,其值为0,再计算0==i+5,也不成立,故表达式值为0。

逻辑运算符和表达式

逻辑运算符c语言中提供了三种逻辑运算符&&与运算||或运算!

非运算与运算符&&和或运算符||均为双目运算符。

具有左结合性。

运算符!

为单目运算符,具有右结合性。

逻辑运算符和其它运算符优先级的关系可表示如下:

按照运算符的优先顺序可以得出:

a>b&&c>d等价于(a>b)&&(c>d)

!

b==c||d

b)==c)||(d

a+b>c&&x+yc)&&((x+y)

逻辑运算的值

逻辑运算的值也为“真”和“假”两种,用“1”和“0”来表示。

其求值规则如下:

1.与运算&&参与运算的两个量都为真时,结果才为真,否则为假。

例如,5>0&&4>2,由于5>0为真,4>2也为真,相与的结果也为真。

2.或运算||参与运算的两个量只要有一个为真,结果就为真。

两个量都为假时,结果为假。

例如:

5>0||5>8,由于5>0为真,相或的结果也就为真

3.非运算!

参与运算量为真时,结果为假;参与运算量为假时,结果为真。

例如:

!

(5>0)的结果为假。

虽然c编译在给出逻辑运算值时,以“1”代表“真”,“0”代表“假”。

但反过来在判断一个量是为“真”还是为“假”时,以“0”代表“假”,以非“0”的数值作为“真”。

例如:

由于5和3均为非“0”因此5&&3的值为“真”,即为1。

又如:

5||0的值为“真”,即为1。

逻辑表达式逻辑表达式的一般形式为:

表达式逻辑运算符表达式其中的表达式可以又是逻

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 人文社科 > 法律资料

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2