IT认证C语言第二章课件

上传人:痛*** 文档编号:206858395 上传时间:2023-05-05 格式:PPT 页数:57 大小:1.17MB
返回 下载 相关 举报
IT认证C语言第二章课件_第1页
第1页 / 共57页
IT认证C语言第二章课件_第2页
第2页 / 共57页
IT认证C语言第二章课件_第3页
第3页 / 共57页
点击查看更多>>
资源描述
第二章 数据的类型与基本操作预备知识基本数据类型与常数的表示变量与内存运算符与表达式输入输出函数2.0 预备知识计算机中数的表示及进制转换v数码、基与权l数码:表示数的符号l基:数码的个数l权:每一位所具有的值v数制语言程序设计 第二章数据描述Cv各种进制之间的转换l二进制、八进制、十六进制转换成十进制u方法:按权相加语言程序设计 第二章数据描述Cv各种进制之间的转换(整数)l二进制、八进制、十六进制转换成十进制u方法:按权相加l十进制转换成二进制、八进制、十六进制u原理:u方法:连续除以基,从低到高记录余数,直至商为0例 把十进制数59转换成二进制数5922921427232120(59)10=(111011)21101111 1 1 0 1 1余余余余余余例 把十进制数159转换成八进制数1598198280(159)10=(237)82 3 7 余 7余 3余 2例 把十进制数459转换成十六进制数4591628161160(459)10=(1CB)161 C B 余11余12余 1语言程序设计 第二章数据描述Cl二进制与八进制之间的转换u二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制u八进制转换成二进制:用3位二进制数代替每一位八进制数例 (1101001)2=(001,101,001)2=(151)8例(246)8=(010,100,110)2=(10100110)2000 0001 1010 2011 3100 4101 5110 6111 7语言程序设计 第二章数据描述Cl二进制与十六进制之间的转换u二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制u十六进制转换成二进制:用4位二进制数代替每一位十六进制数例 2=(0011,0101,0111,1101)2=(357D)16例(4B9E)16=(0100,1011,1001,1110)220000 00001 10010 20011 30100 40101 50110 60111 71000 81001 91010 A1011 B1100 C1101 D1110 E1111 F语言程序设计 第二章数据描述C字节和位v内存以字节为单元组成v每个字节有一个地址v一个字节一般由8个二进制位组成v每个二进位的值是0或101234567012345678910.语言程序设计 第二章数据描述C7643251数值的表示方法原码、反码和补码v原码:最高位为符号位,其余各位为数值本身的绝对值v反码:l正数:反码与原码相同l负数:符号位为1,其余位对原码取反v补码:l正数:原码、反码、补码相同l负数:最高位为1,其余位为原码取反,再对整个数加13126912457810119-5=49+7=16=(14)12语言程序设计 第二章数据描述C原码反码补码+7000001110000011100000111-7100001111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围0111111111111111(-127+127)0111111110000000(-127+127)0111111110000000(-128+127)(用一字节表示数)v负数补码转换成十进制数:最高位不动,其余位取反加1例 补码:11111001 取反:10000110 加1:10000111=-7语言程序设计 第二章数据描述C 基本数据类型数据类型总表C数据类型基本类型构造类型指针类型空类型void定义类型typedef字符类型char枚举类型enum整 型实型单精度型float双精度型double数组结构体struct共用体union短整型short长整型long整型int数据类型决定:1.数据占内存字节数2.数据取值范围3.其上可进行的操作语言程序设计 第二章数据描述C基本数据类型类型符号关键字数的表示范围所占位数整型字符型实型有无(signed)int32-21474836482147483647(signed)short16-3276832767(signed)long32-2147483648214748364732unsigned int042949672953204294967295unsigned longunsigned short16065535有float323.4e-383.4e38有double641.7e-3081.7e308有char8-128127无unsigned char80255说明:数据类型所占字节数在不同的编译器会有所不同,上表以VC6机为例:语言程序设计 第二章数据描述Cu一般用大写字母u是宏定义预处理命令,不是C语句l直接常量:u整型常量 u实型常量 u字符常量 u字符串常量如#define PRICE 302.1.2 常数表示v定义:程序运行时其值不能改变的量(即常数)v分类:l符号常量:用标识符代表常量u定义格式:#define 符号常量 常量例 符号常量举例(ch2_1.c)#define PRICE 30main()int num,total;num=10;total=num*PRICE;printf(total=%d,total);运行结果:total=300语言程序设计 第二章数据描述C&整型常量(整常数)v三种形式:l十进制整数:由数字09和正负号表示.如 123,-456,0l八进制整数:由数字0开头,后跟数字07表示.如0123,011l十六进制整数:由0 x开头,后跟09,af,AF表示.如0 x123,0Xff例 12 与 12Lv整型常量的类型l根据其值所在范围确定其数据类型l在整常量后加字母l或L,认为它是long int 型常量问题:0123 =()100 x123=()100Xff =()1083291255问题:0123 =()100 x123=()100Xff =()10语言程序设计 第二章数据描述C&实型常量(实数或浮点数)v表示形式:l十进制数形式:(必须有小数点)如0.123,.123,123.0,0.0,123.l指数形式:(e或E之前必须有数字;指数必须为整数)如12.3e3,123E2,1.23e4,e-5 ,v实型常量的类型l默认double型l在实型常量后加字母f或F,认为它是float 型语言程序设计 第二章数据描述C&字符常量v定义:用单引号括起来的单个普通字符或转义字符.v字符常量的值:该字符的ASCII码值转义字符及其含义:转义字符含义nvradddtbf“xhh转义字符含义换行垂直制表回车响铃单引号3位8进制数代表的字符水平制表退格换页反斜线双引号2位16进制数代表的字符如 101 -A 012 -n 376 -x61 -a 60 -0 483 -()例:A-101-x41-65如 A65,a97,048,n10如 a A?n 101v转义字符:反斜线后面跟一个字符或一个代码值表示例 转义字符举例(ch2_001.c,ch2_004.c)main()printf(101 x42 Cn);printf(I say:How are you?n);printf(C Programn);printf(Turbo C);运行结果:(屏幕显示)A B CIsay:”How are you?”C ProgramTurbo C例 main()printf(“Yb=n”);运行结果:屏幕显示:=打印机输出:b _above$1233days#33char$123ab语言程序设计 第二章数据描述CC C语言内部预先定义的标识符称为关键字,关键字不能作为用语言内部预先定义的标识符称为关键字,关键字不能作为用户标识符。户标识符。编译程序根据变量定义为其分配指定字节的内存单元.地址int a=1,b=-3,c;abc4字节4字节4字节地址地址.内存1-3随机数变量的定义与初始化v概念:其值可以改变的量v变量名与变量值v变量定义的一般格式:数据类型 变量1,变量2,变量n;v变量初始化:定义时赋初值 例:int a,b,c;float data;决定分配字节数和数的表示范围合法标识符例:int a=2,b,c=4;float data=3.67;char ch=A;int x=1,y=1,z=1;int x=y=z=1;v变量的使用:先定义,后使用例1 int student;stadent=19;/Undefined symbol statent in function main v变量定义位置:一般放在函数开头main()int a,b=2;float data;a=1;data=(a+b)*1.2;printf(“data=%fn”,data);变量定义可执行语句main()int a,b=2;a=1;float data;data=(a+b)*1.2;printf(“data=%fn”,data);Ch2_005.c语言程序设计 第二章数据描述C&整型变量v占字节数随机器不同而不同,一般占一个机器字vshortintlongv可用sizeof(类型标识符)测量&实型变量vfloat:占4字节,提供7位有效数字vdouble:占8字节,提供1516位有效数字&字符型变量v字符变量存放字符ASCII码vchar与int数据间可进行算术运算例 2.3 float a;a=111111.111;/*a=111111.1*/double b;b=111111.111;/*b=111111.111*/例 a=D;/*a=68;*/x=A+5;/*x=65+5;*/s=!+G /*s=33+71;*/没有字符串变量,用字符数组存放语言程序设计 第二章数据描述C例 2.4 void main()char ch1,ch2;ch1=a;ch2=65;printf(“ch1=%c,ch1=%dn”,ch1,ch1);printf(“ch2=%c,ch2=%dn”,ch2,ch2);例 2.5 将小写字母a转换成大写字母后输出#include main()char ch1=b,ch2;int i;i=a-A;ch2=ch1-i;printf(“ch1=%c,ch2=%c,i=%dn”,ch1.ch2,i);宏定义变量定义输出结果语言程序设计 第二章数据描述C2.3 运算符和表达式C运算符算术运算符:(+-*/%+-)关系运算符:(=!=)逻辑运算符:(!&|)位运算符 :(|&)赋值运算符:(=及其扩展)条件运算符:(?:)逗号运算符:(,)指针运算符:(*&)求字节数 :(sizeof)强制类型转换:(类型)分量运算符:(.-)下标运算符:()其它 :(()-)语言程序设计 第二章数据描述C表达式:由运算符与运算对象(变量、常量、函数、表达式)组合而成。表达式:由运算符与运算对象(变量、常量、函数、表达式)组合而成。学习运算符应注意:v运算符功能v与运算量关系l要求运算量个数l要求运算量类型v运算符优先级别v结合方向v结果的类型语言程序设计 第二章数据描述C2.3.1 算术运算符和表达式v基本算术运算符:+-*/%l结合方向:从左向右l优先级:-*/%-+-(2)(3)(4)说明:l“-”可为单目运算符时,右结合性l两整数相除,结果为整数l%要求两侧均为整型数据例 5/2 =-5/2.0 =例 5%2 =-5%2 =1%10 =5%1 =5.5%2例 5/2 =2 -5/2.0=-2.5例 5%2 =1 -5%2 =-1 1%10 =1 5%1 =0 5.5%2 ()语言程序设计 第二章数据描述C例 2.6 将一个三位整数365转换为563,调换个位与百位数字#includevoid main()int x=365,a,b,c,y;c=x%10;b=x/10%10;a=x/100;y=c*100+b*10+a;printf(x=%d,y=%dn,x,y);2.3.2 赋值运算符和表达式v简单赋值运算符l符号:=l格式:变量标识符=表达式l作用:将一个数据(常量或表达式)赋给一个变量l赋值运算符的优先级别很低l赋值运算符不同于数学中的符号v复合赋值运算符l种类:+=-=*=/=%=&=|=l含义:exp1 op=exp2 exp1=exp1 op exp2a+=3a=a+3x*=y+8x=x*(y+8)x%=3x=x%3例 a=3;a=b;b=a;a=a+1 d=func();c=d+2;语言程序设计 第二章数据描述Cv说明:l结合方向:自右向左l优先级:14l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例 3=x-2*y;a+b=3;3=a;例 float f;int i;i=10;f=i;则 f=10.0例 int i;i=2.56;/结果i=2;例:a=b=c=5 a=(b=5)a=5+(c=6)a=(b=4)+(c=6)a=(b=10)/(c=2)/表达式值为5,a,b,c值为5/b=5;a=5/表达式值11,c=6,a=11/表达式值10,a=10,b=4,c=6/表达式值5,a=5,b=10,c=2语言程序设计 第二章数据描述Cv说明:l结合方向:自右向左l优先级:14l左侧必须是变量,不能是常量或表达式l赋值表达式的值与变量值相等,且可嵌套l赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例:a=12;a+=a-=a*a例:int a=2;a%=4-1;a+=a*=a-=a*=3;/a=-264 等价于a=a+(a=a-(a*a)/a=0 等价于a=a+(a=a*(a=a-(a=a*3)语言程序设计 第二章数据描述C数据类型的转换隐式转换v什么情况下发生l运算转换-不同类型数据混合运算时l赋值转换-把一个值赋给与其类型不同的变量时l输出转换-输出时转换成指定的输出格式l函数调用转换-实参与形参类型不一致时转换v运算转换规则:不同类型数据运算时先自动转换成同一类型语言程序设计 第二章数据描述Cdoublefloatlongunsignedintchar,short低高说明:必定的转换运算对象类型不同时转换例 char ch;int i;float f;double d;ch/i +f*d -(f+i)intintdoubledoubledoubledoubledoubledoubleintintdoubledoubledoubledoubledoubledouble10+a +i*f -d/l例 int i;float f;double d;long l;显式转换(强制转换)v一般形式:(类型名)(表达式)例 (int)(x+y)(int)x+y (double)(3/2)(int)3.6 v说明:强制转换得到所需类型的中间变量,原变量类型不变 例 main()float x;int i;x=3.6;i=(int)x;printf(“x=%f,i=%d”,x,i);结果:x=3.600000,i=3精度损失问题较高类型向较低类型转换时可能发生语言程序设计 第二章数据描述C2.3.4 常用数学函数在表达式计算中,如果遇到一般的初等数学函数,可以使用系统提供的标准库函数来完成(1)头文件包含#include (2)函数原型 int abs(int x)double fabs(double x)double sqrt(double x)double pow(double x,double y)(3)参数的定义域 平方根函数,三角函数sin(60*3.14/180)例 2.8 常用数学库函数的用法#include#includevoid main()printf(abs(-5)=%d,abs(5)=%dn,abs(-5),abs(5);printf(sqrt(2)=%20.16fn,sqrt(2);printf(pow(2,3)=%f,pow(2,0.5)=%fn,pow(2,3),pow(2,0.5);printf(exp(1)=%fn,exp(1);printf(sin(x)=%fn,sin(30*3.14/180);v自增、自减运算符+-l作用:使变量值加1或减1l种类:u前置 +i,-i (先执行i+1或i-1,再使用i值)u后置 i+,i-(先使用i值,再执行i+1或i-1)例 j=3;k=+j;j=3;k=j+;j=3;printf(“%d”,+j);j=3;printf(“%d”,j+);a=3;b=5;c=(+a)*b;a=3;b=5;c=(a+)*b;/k=4,j=4/k=3,j=4/4/3/c=20,a=4/c=15,a=4语言程序设计 第二章数据描述C2.3.5 几个特殊的运算符v自增、自减运算符+-l作用:使变量值加1或减1l种类:u前置 +i,-i (先执行i+1或i-1,再使用i值)u后置 i+,i-(先使用i值,再执行i+1或i-1)l说明:u+-不能用于常量和表达式,如5+,(a+b)+u+-结合方向:自右向左u优先级:-+-*/%-+-(2)(3)(4)例-i+-(i+)i=3;printf(“%d”,-i+);/-3 例 j+k;(j+)+k;例-i+i=3;printf(“%d”,-i+);语言程序设计 第二章数据描述C逗号运算符和表达式v形式:表达式1,表达式2,表达式nv结合性:从左向右v优先级:15v逗号表达式的值:等于表达式n的值v用途:常用于循环for语句中例 a=3*5,a*4 a=3*5,a*4,a+5例 x=(a=3,6*3)x=a=3,6*a例 a=1;b=2;c=3;printf(“%d,%d,%d”,a,b,c);printf(“%d,%d,%d”,(a,b,c),b,c);/a=15,表达式值60/a=15,表达式值20/赋值表达式,表达式值18,x=18/逗号表达式,表达式值18,x=3/1,2,3/3,2,3语言程序设计 第二章数据描述C逗号运算符和表达式v形式:表达式1,表达式2,表达式nv结合性:从左向右v优先级:15v逗号表达式的值:等于表达式n的值v用途:常用于循环for语句中例:/*ch2_6.c*/#include main()int x,y=7;float z=4;x=(y=y+6,y/z);printf(x=%dn,x);运行结果:x=3语言程序设计 第二章数据描述C2.4 输入输出函数输入:从计算机输入设备向内存传送数据的过程输出:将主机中的数据传送到计算机输出设备5C语言无I/O语句,I/O操作由函数实现5#include 数据输出格式:格式:printf(“printf(“格式控制串格式控制串”,输出,输出项项表表)功能:按指定格式向显示器输出数据功能:按指定格式向显示器输出数据返值:正常,返回输出字节数;出错,返回返值:正常,返回输出字节数;出错,返回EOF(-1)EOF(-1)格式输出函数v输出项表:要输出的数据(可以没有,多个时以“,”分隔)常量,变量或表达式,个数与格式说明符的个数相同,类型一致v格式控制串:包含两种信息l格式控制符:%修饰符格式描述字符 ,用于指定输出格式l普通字符或转义序列:原样输出v格式描述字符dx,Xoucse,Efg%格式字符:十六进制无符号整数不带符号十进制整数十进制整数指数形式浮点小数单一字符字符串八进制无符号整数小数形式浮点小数e和f中较短一种百分号本身int a=567;printf(“%d”,a);int a=255;printf(“%x”,a);int a=65;printf(“%o”,a);int a=567;printf(“%u”,a);char a=65;printf(“%c”,a);printf(“%s”,“ABC”);float a=567.789;printf(“%e”,a);float a=567.789;printf(“%f”,a);float a=567.789;printf(“%g”,a);printf(“%”);567ff101567AABC5.677890e+02567.789000567.789%l说明u格式字符要用小写u格式字符与输出项个数应相同,按先后顺序一一对应u输出转换:格式字符与输出项类型不一致,自动按指定格式输出例 int a=3,b=4;printf(“%d%dn”,a,b);printf(“a=%d,b=%dn”,a,b);例 int a=3,b=4;printf(“%d%dn”,a,b);printf(“a=%d,b=%dn”,a,b);输出结果:3 4 a=3,b=4v附加格式说明符(修饰符).n对实数,指定小数点后位数(四舍五入)对字符串,指定实际输出位数修饰符功 能m输出数据域宽,数据长度m,左补空格;否则按实际输出输出数据在域内左对齐(缺省右对齐)-指定在有符号数的正数前显示正号(+)+输出数值时指定左面不使用的空位置自动填00在八进制和十六进制数前显示前导0,0 x#在d,o,x,u前,指定输出精度为long型在e,f,g前,指定输出精度为double型l例 int a=1234;float f=123.456;char ch=a;printf(“%8d,%2dn”,a,a);printf(“%f,%8f,%8.1f,%.2f,%.2en”,f,f,f,f,f);printf(“%3cn”,ch);运行 1234,1234结果:123.456000,123.456000,123.5,123.46,1.23e+02 a例 static char a=“Hello,world!”printf(“%sn%15sn%10.5sn%2.5sn%.3sn”,a,a,a,a,a);运行结果:Hello,world!Hello,world!Hello Hello Hel 例 m.n2.4.2 格式输入函数格式:scanf(“格式控制字符串”,地址表)功能:按指定格式从键盘读入数据,存入地址表指定的 存储单元中,并按回车键结束返值:正常,返回输入数据个数v地址表:变量的地址,常用取地址运算符&各项之间用逗号间隔 与格式说明符个数相同、一一对应v格式字符:d,i,o,x,u,c,s,f,e例 scanf(“%d%f”,&a,&b);输入:10 20 则 a=10 b=20例 scanf(“%x”,&a);输入:11 则 a=17v附加格式说明符(修饰符)l修饰符功 能hm*用于d,o,x前,指定输入为short型整数用于d,o,x前,指定输入为long型整数用于e,f前,指定输入为double型实数指定输入数据宽度,遇空格或不可转换字符则结束抑制符,将本输入项在读入后作废,不赋给相应的变量例 scanf(“%4d%2d%2d”,&yy,&mm,&dd);输入 19991015 则1999yy,10 mm,15 dd例 scanf(“%2d%*3d%2d”,&a,&b);输入 1234567 则12a,67b例 scanf(“%3d%2d”,&a,&b);输入 5 8 则a=5,b=8当指定输入数据宽度时,系统自动截取所需数据。当指定输入数据宽度时,系统自动截取所需数据。为双精度型变量输入数据,必须使用为双精度型变量输入数据,必须使用%lf格式控制符格式控制符空格作为数据的间隔,指定宽度不起作用空格作为数据的间隔,指定宽度不起作用输入实型数据时,不能限定输入数据的宽度与小数位数输入实型数据时,不能限定输入数据的宽度与小数位数v输入分隔符的指定l一般以空格、TAB或回车键作为分隔符l其它字符做分隔符:格式串中两个格式符间字符例 scanf(“%d%o%x”,&a,&b,&c);printf(“a=%d,b=%d,c=%dn”,a,b,c);输入 123 123 123 输出 a=123,b=83,c=291例 scanf(“%d:%d:%d”,&h,&m,&s);输入 12:30:45 则12 h,30 m,45 s例 scanf(“%d,%d”,&a,&b)输入 3,4 则3a,4 b例 scanf(“a=%d,b=%d,c=%d”,&a,&b,&c);输入 a=12,b=24,c=36 v说明:l用“%c”格式符时,空格和转义字符作为有效字符输入如 scanf(“%c%c%c”,&c1,&c2,&c3);若输入abc 则ac1,c2,b c3l输入数据时,遇以下情况认为该数据结束:u遇空格、TAB、或回车u遇宽度结束u遇非法输入如 scanf(“%d%c%f”,&a,&b,&c);若输入1234a123o.26 则 1234 a,a b,123 cl输入项参数必须是变量的地址l格式符类型与输入项按顺序结合,类型要一一对应。如果类型不匹配,编译程序不做类型检查。l如果输入数据少于输入项时,必须继续输入,直到满足要求。如果输入数据多于输入项个数,多余的数据作为下一个输入函数的输入数据2.4.3 字符输入输出函数字符输出函数 putchar()格式:putchar(c)参数:c为字符常量、变量或表达式功能:把字符c输出到显示器上返值:正常,为显示的代码值;出错,为EOF(-1)例2.14 字符输出函数的用法格式:getchar()功能:从键盘读一字符返值:正常,返回读取的代码值;出错,返回EOF(-1)字符输入函数 getchar()例 2.15 运行结果:输入:as123输出:as,123l输入函数留下的“垃圾”:getchar()只能接收一个字符。当只有一个getchar()函数时,输入一个字符并按回车键后,字符才能被接收。但是回车键仍保留在键盘缓冲区中。解决方法:(1)用getchar()清除(2)用函数fflush(stdin)清除全部剩余内容(3)用格式串中空格或“%*c”来“吃掉”例 int x;char ch;scanf(“%d”,&x);ch=getchar();printf(“x=%d,ch=%dn”,x,ch);执行:123输出:x=123,ch=10例 int x;char ch;scanf(“%d”,&x);scanf(“%c”,&ch);printf(“x=%d,ch=%dn”,x,ch);执行:123输出:x=123,ch=10关系运算符和表达式v关系运算符l种类:=!=l结合方向:自左向右l优先级别:=!=优先级6(高)优先级7(低)例 ca+b /c(a+b)ab!=c /(ab)!=c a=bc /a=(bc /a=(bc)l关系表达式的值:是逻辑值“真”或“假”,用1和0表示例 int a=3,b=2,c=1,d,f;ab (ab)=c b+cb f=abc/表达式值1/表达式值1/表达式值0/d=1/f=0语言程序设计 第二章数据描述Cl关系运算注意:例 若a=0;b=0.5;x=0.3;则 a=x278在C中是允许的,值为0例 int i=1,j=7,a;a=i+(j%4!=0);则a=2例 a0 结果为 A100 结果为10语言程序设计 第二章数据描述Cl关系运算注意:例 注意区分“=”与“=”int a=0,b=1;if(a=b)printf(“a equal to b”);else printf(“a not equal to b”);例 应避免对实数作相等或不等的判断如 1.0/3.0*3.0=1.0 结果为可改写为:fabs(1.0/3.0*3.0-1.0)1e-60语言程序设计 第二章数据描述Cab!a!ba&ba|b真假真假假假真真逻辑运算符和表达式v逻辑运算符l种类:!&|l逻辑运算真值表lC语言中,运算量:0表示“假”,非0表示“真”,运算结果:0表示“假”,1表示“真”,真假假假假假真真假假真真真假真真语言程序设计 第二章数据描述C!(2)&(11)|(12)高低例 a=x&xb&xy a=b|x=y !a|abl优先级:l结合方向:!:从右向左&:从左向右|:从左向右/(a=x)&(xb)&(xy)/(a=b)|(x=y)/(!a)|(ab)语言程序设计 第二章数据描述C!(2)&(11)|(12)高低l优先级:l结合方向:!:从右向左&:从左向右|:从左向右例 a=4;b=5;!a a&b a|b !a|b 4&0|2 53&2|84-!0 c&d值为1值为0值为1值为1值为1值为1/(53)&2|(8(4-(!0)值为1语言程序设计 第二章数据描述C!(2)&(11)|(12)高低l优先级:l结合方向:!:从右向左&:从左向右|:从左向右l短路特性:逻辑表达式求解时,并非所有的逻辑运算符都被执行,只是在必须执行下一个逻辑运算符才能求出表达式的解时,才执行该运算符例 a&b&c /只在a为真时,才判别b的值;只在a、b都为真时,才判别 c的值例 a|b|c /只在a为假时,才判别b的值;只在a、b都为假时,才判别 c的值例 a=1;b=2;c=3;d=4;m=1;n=1;(m=ab)&(n=cd)/结果m=0,n=1语言程序设计 第二章数据描述C条件运算符与表达式v一般形式:expr1?expr2 :expr3v执行过程v功能:相当于条件语句,但不能取代一般if语句例 if(ab)printf(“%d”,a);else printf(“%d”,b);printf(“%d”,ab?a:b);例 求 a+|b|printf(“a+|b|=%dn”,b0?a+b:a-b);expr1取expr2值取expr3值非0=0例 (a=b)?Y:N (x%2=1)?1:0 (x=0)?x:-x (c=a&c0?1:(xb?a:cd?c:d ab?a:(cd?c:d)vexpr1、expr2、expr3类型可不同,表达式值取较高的类型例 x?a:b /x=0,表达式值为b;x0,表达式值为a xy?1:1.5 /xy ,值为1.0;xy ,值为1.5语言程序设计 第二章数据描述C数制基权表示数码特点10,10,10,十进制数0910逢十进一二进制数0122,2,2,逢二进一八进制数0788,8,8,逢八进一十六进制数09,AF,af1616,16,16,逢十六进一十进制:4956=410+910+510+610二进制:1011=12+02+12+12十六进制:81AE=816+116+1016+1416八进制:4275=48+28+78+58语言程序设计 第二章数据描述C
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 成人自考


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!