网站大量收购独家精品文档,联系QQ:2885784924

noip体系课件语法精讲位运算.pptxVIP

noip体系课件语法精讲位运算.pptx

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

任何信息在计算机中都是采用二进制表示的,数据在计算机中是以补码形式存储的,位运算就是直接对整数在内存中的二进制位进行运算。由于位运算直接对内存数据进行操作,不需要转换成十进制,因此处理速度非常快,在信息学竞赛中往往可以优化理论时间复杂度的系数。同时,一个整数的各个二进制位互不影响,利用位运算的一些技巧可以帮助我们简化程序代码。

位运算符C++提供了按位与()、按位或(|)、按位异或(^)、取反(~)、左移()、右移()这6种位运算符。这些运算符只能用于整型操作数,即只能用于带符号或无符号的char、short、int与long类型。

“ab”是指将参加运算的两个整数a和b,按二进制位进行“与”运算。如果两个相应的二进制位数字都为1,则该位的结果为1;否则为0。这里的1可以理解为逻辑中的true,0可以理解为逻辑中的false。“按位与”其实与逻辑上“与”的运算规则一致。按位与()//?3?-?//?5?-?int?a?=?3;??int?b?=?5;??int?c?=?a??b;????cout??c??endl;??//???

“a|b”是指将参加运算的两个整数a和b,按二进制位进行“或”运算。如果两个相应的二进制位数字有一个为1,则该位的结果为1;否则为0。“按位或”其实与逻辑上“或”的运算规则一致。按位或(|)//?48?-?//?15?-?int?a?=?48;??int?b?=?15;??int?c?=?a?|?b;????cout??c??endl;??//?63?-?

“a^b”是指将参加运算的两个整数a和b,按二进制位进行“异或”运算。如果两个相应的二进制位数字不相同,则该位的结果为1;否则为0。按位异或(^)//?52?-?//?15?-?int?a?=?52;??int?b?=?15;??int?c?=?a?^?b;????cout??c??endl;??//?59?-?

“~a”是指将整数a的各个二进制位都取反,即1变为0,0变为1。“~”是一元运算符。取反(~)cout??~9??endl;???/*?????9?-????取反?-补码?????????????反码?????????????原码??????????????最高位?1?表示负数??-10?*/??

“ab”是指将整数a的各个二进制位左移b位,高位丢弃,低位用0补齐。需要注意的是b必须是非负整数。在高位没有1丢弃的情况下,a1相当于a*2。左移()char?a?=?(1432);??printf(%d,?a);??????/*?????143?-??左移2?-?1000111100??60?*/??

“ab”是指将整数a的各个二进制位右移b位,低位丢弃。对于无符号数,高位补0。对于有符号数,某些机器将对左边空出的部分用符号位填补(即“算术移位”),而另一些机器则对左边空出的部分用0填补(即“逻辑移位”)。同样,b必须是非负整数。a1相当于a/2。右移()char?a?=?(15??2);??printf(%d,?a);??????/*???????15?-???右移2?-?3?*/??char?a?=?(-15??2);??printf(%d,?a);??????/*?????15?-??反码?-??补码?-?右移2?-?1111110001???反码?-??原码?-?-4?*/??

位运算符也可以与赋值运算符组成复合运算符。例如a=b相当于a=ab,a=2相当于a=a2。位运算符也是有优先级的,“~”的运算优先级高于“乘除”而与“!”、“++”、“--”一致,“”和“”的运算优先级低于“加减”,“”的运算优先级低于“关系运算”而高于“^”,“^”的优先级高于“|”,而“|”的优先级高于“”和“||”。为了避免出错,增强程序的可读性,利于调试,建议在需要的地方添加括号来保证优先运算。比如15-1,建议写成1(5-1),等价于14。

#include?iostream??using?namespace?std;????int?main()?{??????int?x?=?3,?y?=?9,?z;????

您可能关注的文档

文档评论(0)

152****0921 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档