C++程序设计 第2章 变量和表达式1

上传人:夏** 文档编号:569815785 上传时间:2024-07-31 格式:PPT 页数:131 大小:567.50KB
返回 下载 相关 举报
C++程序设计 第2章 变量和表达式1_第1页
第1页 / 共131页
C++程序设计 第2章 变量和表达式1_第2页
第2页 / 共131页
C++程序设计 第2章 变量和表达式1_第3页
第3页 / 共131页
C++程序设计 第2章 变量和表达式1_第4页
第4页 / 共131页
C++程序设计 第2章 变量和表达式1_第5页
第5页 / 共131页
点击查看更多>>
资源描述

《C++程序设计 第2章 变量和表达式1》由会员分享,可在线阅读,更多相关《C++程序设计 第2章 变量和表达式1(131页珍藏版)》请在金锄头文库上搜索。

1、第二章第二章 变量和表达式变量和表达式内容nC+语言的字符集和单词n数据类型和存储类型n常量n变量n运算符n表达式n类型转换nC+ 程序的结构n标识符模板1 1、C+C+的符号系统的符号系统n主要讨论C+的字符集和标识符的构词规则。 C+的字符集是ASCII字符集的子集,包括以下几类字符: n英文字母,AZ,az(必须区分大小写)n数字字符:09n运算符,例如:+、-、*、/、%,等等n标点符号,例如:,、;和各种括号n其他符号,例如下划线_、美元符号$、井号#等2、标识符、标识符n标识符是由若干个字符构成的“程序单词”,用来标记程序中的各种语法成分,例如标识变量、函数等等n与一个函数或数据对

2、象有关的,有字母(A-Z, a-z)、数字(0-9)和下划线组成,但开头字符。n用途n用于标识一个函数或数据对象、自定义类型的名称标识符n构成构成规则n组成标识符的字符只能是:字母、数字、下划线; n标识符的首字符必必须是是字母或下划字母或下划线、不能是数字符,中间不能出现空格字符;n标识符的长度(字符数)是任意的,但一般仅前31个字符有效;n不能与系统保留字同名;n尽量能做到“见名知义”实例实例n例2-1n AB1,ab1,Rec_Count,RecCount均是合法的标识符,注意AB1与ab1如果同时用在同一个程序中,是两个不同的标识符。n例2-2n1a,%name,$addr均是非法的标

3、识符。标识符举例()n正确的标识符( id) : nsum_of_squares j9 box_22AnGetData Bin3D4 count A a n不正确的标识符: n40Hours Get Datanbox-22 cost_in_$ int nage# 2000TaxRate Age-Of-Cat标识符举例()n保留字不可以用作标识符,P683 例如: if 、else 等不可以用作标识符 保留字: continue 、while、 case 、mainn标识符区分大小写 例如: ba 和 Ba 是不同的两个标识符n使用有意义的、可读性好的标识符 例如: 用average 表示平均的

4、量的标识符 用sum 表示和的量标识符3系统保留字系统保留字n保留字是系统定义的特殊标识符(专用词汇)。通常用来作为数据类型描述符(类型名),语句成分描述符等。n例2-3 int、float数据类型描述符类型名; if、for 语句成分描述符。nANSI C设置32个保留字,ANSI C+在此基础上增加了29个保留字C+ 保留字保留字nAppendix A ,P683nAnd 、not、this、union、whileC+ Data Typesstructuredarray struct union class addresspointer referencesimple integral e

5、numchar short int long boolfloatingfloat double long doublenC+ 数据数据类型分型分为简单类型(基本型(基本类型)、构造型)、构造类型型 和地址和地址类型(指型(指针类型)型) C+C+的简单数据类型(的简单数据类型(Simple Data TypesSimple Data Types)简单数据类型(简单数据类型(simple types)整型(整型(integral) 浮点型浮点型(floating)char short int long bool enum float double long doubleunsignedC+中的标

6、准数据类型n整型(整型(Integral Types)n表示整个数据大小和它表示整个数据大小和它们的的负号号n声明声明为 int, short, or longn浮点型(浮点型(Floating Types)n用小数点的数据表示的用小数点的数据表示的实型数型数值n声明声明为 float 或或 doublen字符型字符型(Character Type)n表示表示单一的字符一的字符n声明声明为 charC+的标准数据类型n整型n声明为 int, short, or longn例如:4578 -4578 0n实型n用带有小数点的数值表示n声明为 float, or doublen例如: 95.274

7、 95. .265n字符型n表示单个字符n声明为 charn例如: B d 4 ?*两种重要的数据类型nchar 单一字符类型n在字符集中表示一个字符 ( ASCII , EBCDIC , Unicode , GB ).nP689 Appendix EnA a 1 ? nnstring 字符序列nProgramming C+ hellon a n字符串模板,用 #include n空字符(0) 结束标志例子#include int main()char a=a;coutChar a takes bytes: sizeof(a)endl;coutvalue of a is: aendl;int

8、b;coutInt b takes bytes: sizeof(b)endl;coutvalue of b is: bendl;b=a;coutvalue of b is: bendl;return 0;程序的输出nChar a takes bytes: 1nvalue of a is: anInt b takes bytes: 4nvalue of b is: -858993460nvalue of b is: 97 整型数据整型数据nchar, short, int, long 类型表示不同大小的整型数.占有的空间的大小依赖于机器. 利用sizeof 操作符可以得到在你机器中占有的空间大小

9、 .n例如: sizeof(int) 得到的是int类型占有的字节数 sizeof(char)=sizeof(short)= sizeof(int)= sizeof(long)n在 32位计算机中: n char : 1 字节(byte) -128,127 n short : 2字节 (byte) -32768,32767 n int : 4字节 (byte) -2147483648, 2147483647 n long : 4字节 (byte) -2147483648, 2147483647 nMost compilers dont give error message when integ

10、er overflow occurs. e.g. INT_MAX +1 INT_MIN整型量(整型量(int)n十十进制(制(Decimal)n 22 16 1 498 0 4600 -378 -912n八八进制(制( Octal )n 022 015n十六十六进制(制(Hexadecimal)n 0xFF 0x10科学计数法 2.7E4 means 2.7 x 10 4 = 27000.02.7E-4 means 2.7 x 10 - 4 = 0.00027例如:例如:main() float a= 2.7E4 +8000.3; 数据类型 常量与变量#include #include usi

11、ng namespace std;using namespace std;int main()int main() const int PRICE=30; const int PRICE=30; int num,total; int num,total; float v ,r,h; float v ,r,h; num=10; num=10; total=num*PRICE; total=num*PRICE; couttotal endl; couttotal endl; r=2.5; r=2.5; h=3.2; h=3.2; v=3.14159*r*r*h; v=3.14159*r*r*h;

12、coutvendl; coutvendl; 常量常量变量变量变量先声变量先声明后使用明后使用符号常量符号常量#include using namespace std;int main() const int PRICE=30; int num,total; float v ,r,h; num=10; total=num*PRICE; couttotal endl; r=2.5; h=3.2; v=3.14159*r*r*h; coutv endl; 数据类型 整型数据整型常量shortunsigned short 2字节intunsigned int 4字节longunsigned long

13、4字节整型变量整型变量声明数据类型 整型数据及取值范围类型说明符 位数数值范围短整短整shortshort1616-32768 32767-32768 32767基本基本 intint32 32 -2-231 31 (2 (23131-1)-1)长整整longlong3232-2-231 31 (2 (23131-1)-1)无符号无符号unsigned shortunsigned short16160 65535 0 65535 unsigned intunsigned int32320 (20 (23232-1)-1)unsigned longunsigned long32320 (20 (

14、23232-1)-1)#include using namespace std;int main() const int PRICE=30; int num,total; float v ,r,h; num=10; total=num*PRICE; couttotalendl; r=2.5; h=3.2; v=3.14159*r*r*h; coutvendl; 数据类型 实型数据实型常量float 4float 4字节字节 3.41038 7位有效数字double 8double 8字节字节 1.710308 15位有效数字long double long double 8 8字节字节 1.7

15、10308 15位有效数字实型变量默认为double型后缀 F(或 f)为 float型后缀 L(或 l)为 long double型浮点数据值n浮点数据有整数部分和小数部分, 中间是小数点,或者只有整数部分或小数部分,但不能两者都没有.n例如: 18.4 500. .8 -127.358 n或者,浮点数据可具有指数部分, 科学计数法:n例如: 1.84E1 5E2 8E-1 -.127358E3 数据类型 字符型数据(一)n字符常量n单引号括起来的一个字符,如:a, D, ?, $n字符变量n用来存放字符常量例:char c1,c2; c1=a; c2=A;n字符数据在内存中的存储形式n以A

16、SCII码存储,占1字节,用7个二进制位n字符数据的使用方法n字符数据和整型数据之间可以运算。n字符数据与整型数据可以互相赋值。n字符串常量例:CHINA a a所以:char c; c=a;C H I N A 0a 0aPage 27 数据类型 字符型数据(二)例如n#include n main( )n char c1,c2;n c1=a;n c2=b;n c1=c1-32;n c2=c2-32;n coutc1c2endl;nreturn 0;n nnewline(换行符) nnhorizontal tab(水平制表键) tnvertical tab(垂直制表键) vnbackspace

17、(退格键) bncarriage return (回车键) rnformfeed (进纸键) fnalert (beel) (响铃符) a nbackslash (反斜杠键) nquestion mark (问号) ?nsingle quote (单引号) ndouble quote (双引号) 数据类型 布尔(bool)型数据n布尔型变量的说明:例:bool flag;n布尔型数据的取值:只有 false 和 true 两个值bool 数据类型数据类型nbool类型是一种固有的型是一种固有的类型型n仅有两种值: true 和false n我们可以声明一个变量为bool类型 n每个bool类型

18、变量包含 true 或 false的值 (true-1, false-0)bool hasFever; / true if has high temperaturebool isSenior; / true if age is at least 55 在在C+中中n数值 0 表示 falsen任何非零数值表示true 数据类型 变量初始化例: int a=3;int a=3; double f=3.56; double f=3.56; char c=a; char c=a; int c(5); int c(5);Page 33数据类型 混合运算时的类型转换n不同类型数据进行混合运算时,C+编译

19、器会自动进行类型转换。n为了避免不同的数据类型在运算中出现类型问题,应尽量使用同种类型数据。n可以采用强制类型转换:例如:float c;int a,b;c=float(a)/float(b); 或 c=(float)a/(float)b; 变量的存储类型nauton属于暂时存储,其存储空间可以被若干变量多次覆盖使用。nregistern存放在通用寄存器中。nexternn在所有函数和程序段中都可引用。nstaticn在内存中是以固定地址存放的,在整个程序运行期间都有效。数据和数据类型n数据被存储在计算机的内存(memory)中n每一个内存区有唯一的地址( address)n数据类型 一系列指

20、定的数值以及这些数值上的操作nC+允许程序员定义自己的数据类型n每个数据必须具有指定的类型声明声明n声明将一个标识符与一个数据对象、函数或数据类型联系起来,以便程序员可以利用名称使用该对象。n在一个程序中,每个标识符是不同的(不同的量用不同的标识符表示)n每个标识符在使用前必须先声明n声明必须用分号结束. nchar letter;nchar ch;n一条声明语句中可以声明几个变量.n char letter, ch;n例如:nint n; /静态分配nint* nPtr = new int; /动态分配nvoid instructions();nbool user_says_yes();声明

21、声明什么是变量?n变量是一个用标识符标识的内存位置. sum=a 0110100010001110 an声明一个变量包括变量名称和它的数据类型n例如: int d=5;nBook p35 figure 2-1声明的任务int ageOfDog;int ageOfDog;float taxRateY2K;float taxRateY2K;char middleInitial;char middleInitial; 声明使编译器给变量分配内存单元,并将标识符与内存位置(地址)联系起来4 bytes for taxRateY2K4 bytes for taxRateY2K1 byte for mid

22、dleInitial1 byte for middleInitial#include int main()/ int 类型的对象int value = 2;int pow = 10;cout value raised to the power of pow : t;int res = 1; / 保存结果/ 循环控制语句: 反复计算res/ 直至cnt 大于powfor ( int cnt=1; cnt = pow; +cnt)res = res * value;cout res endl;常量常量n字面常量(字面常量(Literal value )n常量数常量数值例如:例如:A string

23、100 3.1415926n命名常量命名常量 (Named constant)在声明在声明语句中用常量修句中用常量修饰例如:例如: 常量串常量串 BOOK_TITLE=programming in C+;什么是命名常量命名常量 ?n命名常量命名常量 是我是我们用用标识符指定的内存位符指定的内存位置置.其中的数其中的数值不能不能够改改变的的. VALID CONSTANT DECLARATIONSVALID CONSTANT DECLARATIONS const string STARS = const string STARS = “*” ; ; const float NORMAL_TEMP

24、 = 98.6 ; const float NORMAL_TEMP = 98.6 ; const char BLANK = const char BLANK = ; ; const int VOTING_AGE = 18 ; const int VOTING_AGE = 18 ; const float MAX_HOURS = 40.0 ; const float MAX_HOURS = 40.0 ;n一些一些惯用法用法算术操作符算术操作符n一元操作符(一元操作符(Unary) : +(plus) -(minus)n二元操作符(二元操作符(Binary): + - * /(integral,f

25、loating-point )n%(modulus)(integral only)n-3%2 /-1n7.0/2.0 / 3.5 double/double doublen7/2 / 3 int/int int除法操作符n除法操作的结果依赖于它的操作数的类型n如果操作数至少有一个是浮点类型,则结果为浮点类型. 否则, 结果为整型. n例如: 11 / 4 结果为 2 11.0 / 4.0 结果为 2.75 11 / 4.0 结果为 2.75MainMain函数返给操作系统一个整型数值函数返给操作系统一个整型数值/*/ FreezeBoil program/ This program compu

26、tes the midpoint between/ the freezing and boiling points of water/*#include using namespace std;const float FREEZE_PT = 32.0 ; / Freezing point of waterconst float BOIL_PT = 212.0 ; / Boiling point of waterint main ( ) float avgTemp ; / Holds the result of averaging / FREEZE_PT and BOIL_PT主函数主函数续续

27、cout Water freezes at FREEZE_PT endl ; cout and boils at BOIL_PT degrees. endl ; avgTemp = FREEZE_PT + BOIL_PT ; avgTemp = avgTemp / 2.0 ; cout Halfway between is ; cout avgTemp degrees. endl ; return 0 ;模操作n取模运算符 %只能用于两个整数的操作数,有一个整型的结果. n结果为整型除法的余数. 例如:11 % 4 结果 3 因为)411283 C+ C+操作符操作符8int age;age

28、= 8;age = age + 1; age9age+age+age相当于相当于age=age+1age=age+1先增值再使用先增值再使用ageage前缀型增量运算符8int age;age = 8;+age; age9age后缀型增量运算符8int age;age = 8;age+; age9ageage+age+相当于相当于age=age+1age=age+1先使用先使用ageage再增值再增值自减操作符自减操作符100int dogs;dogs = 100;dogs-; dogs99dogsdogs- 相当于相当于dogs = = dogs -1 -1先使用先使用dogs再减一再减一前

29、缀和后缀操作符n前缀和后缀的区别:n后缀(Suffix): 表达式(num+)值为操作数原始值. n前缀(Prefix):表达式(+num)值为操作数新的值. n例如: nint num=10; cout num+ num; 10 11nint num=10; cout +num b? 1:2C+的一些操作符 P684Precedence OperatorDescription Higher ( ) 函数调用(Function ) +正(Positive) -负(Negative) *乘Multiplication) / 除(Division)优先级别 %模Modulus (remainder

30、) +加Addition -减SubtractionLower = 赋值Assignment优先级别n当有多个操作符时,优先级别决定了哪个运算符先运算nAppendix B关联n当有两个优先级别相同运算符的表达式,左边运算符的优先级别高,从左到右运算n在 C+ 二元操作符中, * , / , % , + , - 都是左关联 n表达式 9 - 5 - 1 表示 ( 9 - 5 ) - 14 - 1 37 * 10 - 5 % 3 * 4 + 9表示表示 (7 * 10) - 5 % 3 * 4 + 9 70 - 5 % 3 * 4 + 970 - (5 % 3) * 4 + 9 70 - 2 *

31、 4 + 9 70 - ( 2 * 4 ) + 9 70 - 8 + 9 ( 70 - 8 ) + 9 62 + 9 71表达式的值圆括号()n圆括号能够改变运算顺序.n圆括号中的部分先计算n计算 (7 * (10 - 5) % 3) * 4 + 9 ( 7 * 5 % 3 ) * 4 + 9 ( 35 % 3 ) * 4 + 9 2 * 4 + 9 8 + 9 17算术运算符与算术表达式n基本算术运算符 + - * /(若整数相除,结果取整) %(取余,操作数为整数)n优先级与结合性先乘除,后加减,同级自左至右n+, -(自增、自减)例:i+; - j;Page 68赋值运算符和赋值表达式

32、简单的赋值运算符=n举例n=n+5n表达式的类型等号左边对象的类型n表达式的值等号左边对象被赋值后的值Page 69赋值运算符和赋值表达式 复合的赋值运算符n有10种复合运算符:+=, -=, *=, /=, %=,=,&=,=,|= n例a+=3 等价于 a=a+3x*=y+8 等价于 x=x*(y+8)赋值运算符和赋值表达式 赋值表达式举例a=5表达式值为5a=b=c=5表达式值为5,a,b,c均为5a=5+(c=6)表达式值为11,a为11,c为6a=(b=4)+(c=6) 表达式值为10,a为10,b为4,c为6a=(b=10)/(c=2) 表达式值为5,a为5,b为10,c为2a+=

33、a-=a*a 相当于 a=a+(a=a-a*a)Page 71逗号运算和逗号表达式n格式表达式1,表达式2n求解顺序及结果先求解1,再求解2,最终结果为表达式2的值n例a=3*5 , a*4 最终结果为60Page 72关系运算与关系表达式n关系运算是比较简单的一种逻辑运算,优先次序为: = = != 优先级相同(高) 优先级相同(低)n 关系表达式是一种最简单的逻辑表达式其结果类型为 bool,值只能为 true 或 false。n例如:ab,cb)&(xy) 其结果类型为 bool,值只能为 true 或 false int x, y ; x = 4; y = 6;表达式表达式 值x y

34、truex + 2 = y truey = x falsey = x+2 truey = x + 3 7 (true) n例如bool a;int c=5,g=7;a=cg; if (a) 条件运算符与条件表达式n一般形式表达式1?表达式2:表达式3表达式1 必须是 bool 类型n执行顺序n先求解表达式1,n若表达式1的值为true,则求解表达式2,表达式2的值为最终结果n若表达式1的值为false,则求解表达式3,表达式3的值为最终结果n例: x=ab? a:b;条件运算符与条件表达式n注意:条件运算符优先级高于赋值运算符,低于逻辑运算符表达式2、3的类型可以不同,条件表达式的最终类型为

35、2 和 3 中较高的类型。n例: x=ab? a:b;sizeof 运算符n语法形式sizeof (类型名)或 sizeof (表达式)n结果值:“类型名”所指定的类型或“表达式”的结果类型所占的字节数。n例:sizeof(short)sizeof(x)位运算按位与(&)n运算规则n将两个运算量的每一个位进行逻辑与操作n举例:计算 3 & 5 3: 0 0 0 0 0 0 1 1 5:(&) 0 0 0 0 0 1 0 13 & 5: 0 0 0 0 0 0 0 1n用途:n将某一位置0,其他位不变。例如:将char型变量a的最低位置0: a=a&0376;n取指定位。例如:有char c;

36、int a; 取出a的低字节,置于c中:c=a&0377;位运算按位或(|)n运算规则n将两个运算量的每一个位进行逻辑或操作n举例:计算 3 | 5 3: 0 0 0 0 0 0 1 1 5:(|) 0 0 0 0 0 1 0 13 | 5: 0 0 0 0 0 1 1 1n用途:n将某些位置1,其他位不变。例如:将 int 型变量 a 的低字节置 1 : a = a | 0xff;位运算按位异或()n运算规则n两个操作数进行异或:若对应位相同,则结果该位为 0,若对应位不同,则结果该位为 1,n举例:计算 071052 071: 0 0 1 1 1 0 0 1 052: () 0 0 1 0

37、 1 0 1 0 071052 : 0 0 0 1 0 0 1 1位运算按位异或()n用途:n使特定位翻转(与0异或保持原值,与1异或取反) 例如:要使 01111010 低四位翻转: 0 1 1 1 1 0 1 0 () 0 0 0 0 1 1 1 10 1 1 1 0 1 0 1位运算取反()单目运算符,对一个二进制数按位取反。例: 025:0000000000010101 025:1111111111101010位运算移位n左移运算()右移后,低位:舍弃高位:无符号数:补0 有符号数:补“符号位”运算符优先级括号+,-,sizeof*, /, %+, -=, !=位运算&|?:赋值运算逗

38、号运算低高混合运算时数据类型的转换 隐含转换n一些二元运算符(算术运算符、关系运算符、逻辑运算符、位运算符和赋值运算符)要求两个操作数的类型一致。n在算术运算和关系运算中如果参与运算的操作数类型不一致,编译系统会自动对数据进行转换(即隐含转换),基本原则是将低类型数据转换为高类型数据。char,short,int,unsigned,long,unsigned long,float,doublechar,short,int,unsigned,long,unsigned long,float,double低低 高高混合运算时数据类型的转换 隐含转换n当参与运算的操作数必须是bool型时,如果操作数

39、是其它类型,编译系统会自动将非0数据转换为true,0转换为false。n位运算的操作数必须是整数,当二元位运算的操作数是不同类型的整数时,也会自动进行类型转换,n赋值运算要求左值与右值的类型相同,若类型不同,编译系统会自动将右值转换为左值的类型。混合运算时数据类型的转换 强制类型转换n语法形式:类型说明符(表达式)或(类型说明符)表达式n强制类型转换的作用是将表达式的结果类型转换为类型说明符所指定的类型。变量赋初值n变量赋初值可用赋值运算符=;变量声明:string firstName ;char middleInitial ;char letter ;int ageOfDog;有效的赋值语

40、句:有效的赋值语句: firstName = “Fido” ;middleInitial = X ;letter = middleInitial ;ageOfDog = 12 ;什么是C+的表达式?n表达式是变量、常量和操作符号的有效排列。n在C+每个表达式能够计算得到一个给定类型的数值n表达式的值 9 + 5 is 14赋值操作的语法 Variable = Expressionn表达式右侧的式子必须可以计算得到一个数值.n计算的结果存储在左侧变量的内存单元中n变量 左侧数值 ( lvalue )n表达式的类型必须与变量的类型相匹配.n例如:n int a=0.4; 得不到正确的结果正确赋值语

41、句的例子nstring firstName, n middleName,n lastName,n name;n name = firstName+middleName+lastName;n说明明: 符号符号 + 表示串表示串联n给一个字符串一个字符串变量量赋值时,等号右,等号右侧的表达式必的表达式必须是是一个字符串的表达式、文字串或一个字符一个字符串的表达式、文字串或一个字符. 问题的提出问题的提出n需求变化引发软件危机n1968年北大西洋公约组织的计算机科学家在联邦德国召开的会议上第一次提出了“软件危机”。n软件危机包含两方面问题:a)如何开发软件,以满足不断增长,日趋复杂的需求;b)如何维

42、护数量不断膨胀的软件产品 n面向对象程序设计方法的产生n类继承n类封装大型项目的开发流程n问题的确定(需求分析、了解业务、目标的精确化)n项目设计(UML建模,模块划分,组织关系,数据库设计等)n具体模块实现n选择数据结构(List, Stack, Queue)n分析算法n整体测试(白盒法、黑盒法)n后期维护、二次开发第一个例子第一个例子#include using namespace std;int Square( int );int Cube( int );int main() cout The square of 27 is Square(27) endl; cout and the c

43、ube of 27 is Cube(27) endl; return 0;int Square( int n ) return n * n;int Cube( int n ) return n * n * n;C+ 的表达式b2 - 4ac的平方根 sqrt ( b * b - 4.0 * a * c )myAge 和yourAge平均数的平方根sqrt ( ( myAge + yourAge ) / 2 )格式输出格式输出n整形和字符串整形和字符串n浮点数据浮点数据setw 操作符操作符-设置字段宽度设置字段宽度n“set width” 控制下一个要输出的数据项占的字符位置数,适用于数值和串

44、不用于字符型数据n例如:cout setw(fieldwidth) dataitem n数据dataitem 将右对齐打印输出n如果fieldwith小于dataitem 的长度,则自动扩大长度,输出全部字符. n设置字段的宽度是先做的内容.举例:举例:n int ans = 33 , num = 7132;n cout setw(4) ansn setw(5) numn setw(4) Hi; bb33b7132bbHi注意:#include / setw(4) 浮点型数据浮点型数据n缺省时, 大的浮点数大的浮点数 用科学计数法输出n例如: 123456789.5 1.234567E+08

45、n操作符fixed用于强制输出所有的浮点数,以十进制形式输出. n例如. cout fixed 123456789.5 ; 123456789.5 n操作符showpoint用于强制所有数据的输出为小数形式.n操作符setprecision(number)用于控制输出数据的小数点的位置. 举例:举例:n float x = 310.0 , y= 4.827 ; cout fixed setw(10) setprecision(2) x ;n bbbb310.00#include iostream.h#include iomanip.h/using namespace std;int main(

46、)float gg=3241.323441;coutsetiosflags(ios:fixed)setprecision(5)gg;return 0;举例#include / for setw( ) and setprecision( )#include using namespace std;int main ( ) float myNumber = 123.4587 ; cout fixed showpoint ; / use decimal format / print decimal points cout “Number is ” setprecision ( 3 ) myNumbe

47、r endl ; return 0 ; 输出 Number is 123.459数值需要四舍五入,输出数据末尾需要保数值需要四舍五入,输出数据末尾需要保留三位数字留三位数字 nFixed是是C+中的,中的,n#include n#include iomanip nusing namespace std;C+ 程序的结构程序的结构n一个或多个函数的集合n必须有一个函数称为mainn程序的执行从函数main开始n操作系统调用main函数语法和语义语法和语义n语法法n用编程语言编写程序的形式规则n例如:每条语句用分号结束。n语义n利用编程语言编写程序时,决定指令意义的一些规则n编写的程序的功能是否正

48、确n例如:要完成求几个数的平均值,能否符合要求元语言n最早的一种面向计算机的元语言nBNF 是一种非常简单语言,导致语法定义过长并难读n采用语法模板标识符模板标识符模板语法模板定义n下载网址: 的main函数的说法,错误的是:A)每个程序必须有一个称为main的函数. B)程序执行开始于main 函数中第一个可执行的语句.C) main函数必须调用另一个函数. D)函数前的int词,表示main 函数返回一个整型的数值(给操作系统)n答案:C练习n下面哪一个是 C+中的无效标识符? A)Hi_There B)top40 C)UpAnDdOwN D)3BlindMice E)CAPS n答案:D

49、练习n下面哪一个是 C+中的无效标识符? A) myName B)little C)X123Y D)Go Home E)IdEnTiFiEr n答案:D练习n下面哪一个是合法的串赋值? A)name = Jones; B)name = Jones; C)name = D + Jones; D)b and c above n答案B练习n下面哪一种能给字符型变量赋初值? A)t B)2 C)$ D)All of the above n答案D练习n下面哪一种语句能在输出行上打印出HappyBirthday? A)cout Happy endl;cout Birthday endl; B)cout H

50、appy;cout Birthday endl; C)cout HappyBirthday endl; D)b and c above E)a, b, and c above n答案D练习n一个文本串只要用双引号,就可以表示多行的内容.A)TrueB)FalsenFalse练习n语句const char INITIAL = G;是赋值语句的一个例子. A)TrueB)FalsenFalsen#include nusing namespace std;nint main ( )nnint a=-1;nunsigned short b=a;ncoutbendl;nreturn 0;nn结果65535

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号