- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第二章基本数据类型和表达式.ppt
信息技术学院软件教研室 【教学目的与要求】 理解C++程序的基本数据类型、运算符、表达式, 掌握常量、变量的使用方法,运算符的优先级和结合性。 【教学重点与难点】 常量、变量的定义和使用,运算符的运算规则、优先级和结合性。 【教学方法】 讲授与上机相结合。 【教学内容】 第二章 基本数据类型和表达式 准备知识 常用进位计数制 准备知识 不同进制之间的转换 1.其它进制与十进制的相互转换-按权展开 例1(11101.011)2=1×24+1×23+1×22+0×21+1×20+0×2-1 +1×2-2+1×2-3=(29.375)10 例2 (35.3)8=3×81+5×80+3×8-1=(29.375)10 例2 (1D.6)16=1×161+13×160=(29.375)10 表1-1 不同数制各位的权数(用十进制数表示) 2. 十进制数据转换成其它进制 整数部分采用的是倒除法,即“除基数取余”的方法。小数部分采用“乘基数取整”法。 【例2】将(236)D转换成二进制。转换过程如图1-1所示。 3.二进制数与十六进制数的相互转换 将二进制数转变成十六进制数由于16=24,所以在将二进制数转换成十六进制数时,从小数点向两边,每四位二进制数划为一组,用一位十六进制数代替,也称为“以四换一”;十六进制数转换成二进制数时正好相反,一位十六进制数用四位二进制数来替换,也称“以一换四”。 同理二进制转换为八进制采用“以一换三”。 准备知识 计算机中数据的表示方法 1.原码(机器数)一个二进制数同时包含符号和数值两部分,用最高位表示符号,其余位表示数值,这种表示带符号数的方法为原码表示法。 2.反码反码是另一种表示有符号数的方法。对于正数,其反码与原码相同;对于负数,在求反码的时候,除了符号位外,其余各位按位取反,即“1”都换成“0”,“0”都换成“1”。 3.补码补码是表示带符号数的最直接方法。对于正数,其补码与原码相同;对于负数,则其补码为反码加1。 2.1 C++的数据类型 2.1 C++的数据类型 2.2 常量与变量 2.2.2 变量 2.2.3 整型数据 基本数据类型测试 2.2.4 字符数据 2.2.5 字符串常量 2.2.6 实型数据 2.2.7 逻辑数据 2.2.8 枚举常 量 2.3 运算符 2.3.1 运算符的说明 运算符的说明 2.3.2 运算符的种类 2.4 C++ 常用数学函数 2.4.2 函数调用 2.4.3 函数应用举例 2.5 C++ 表达式 2.5.1 C++ 表达式书写 2.5.2 C++ 表达式分类 2.5.3 类型转换 2.5.4数据的输入与输出 2.5.5 C++ 表达式综合练习 表1-4 十进制数和BCD码对照表 表1-5 7位ASCII码表 (例3 –1 表达式计算。 (1) float x=2.5, y=4.7; int a=7; 计算x + a%3*(int)(x+y)%2/4 ⑦ ① ④ ③ ② ⑤ ⑥ ① a%3等于1。 ② x+y等于7.2。 ③(int)(x+y)等于7 。 ④ a%3*(int)(x+y)等于7。 ⑤ a%3*(int)(x+y)%2等于1。 ⑥ a%3*(int)(x+y)%2/4等于0。 ⑦ x+a%3*(int)(x+y)%2/4等于2.5+0, 结果为2.5。 第二项将由整型自动转换为双精度型进行运算, 计算结果为双精度型。 (2) int a=2, b=3; float x=3.5, y=2.5; 计算(float)(a+b)/2 +(int)x%(int)y ② ① ③ ⑦ ④ ⑥ ⑤ ① a+b等于5。 ② (float)(a+b)等于5.0, 强制转换成float型。 ③ (float)(a+b)/2等于5.0/2.0, 结果为2.5。 ④ (int)x等于3, 强制转换成int型。 ⑤ (int)y等于2, 强制转换成int型。 ⑥ (int)x%(int)y等于1。 ⑦ (float)(a+b)/2+(int)x%(int)y等于2.5+1.0, 结果 为3.5(双精度型)。 (3) int i=3; float f=1.0; double d=2.3; 计算10 +′a′+i*f-d ① ③ ② ④ ① ′a′转换成97, 10+′a′等于107。 ② i, f转换成
文档评论(0)