2025年C语言 按位异或运算

C语言 按位异或运算按位异或运算 规律 无论 0 或 1 异或 1 取反 异或 0 不变 变量交换 题一 给定两个数 a 和 b 用异或运算交换它们的值 思路 1 中间量 t a b 2 b tb 相当于 abb 根据异或性质知道 ab b a 所以 b t b 就是 b a 异或性质 异或两次不变 3 a t a 道理同上 出现奇数次的数 题二 输入 n 个数

按位异或运算:
规律:无论0或1,异或1取反,异或0不变

变量交换:
题一:给定两个数 a 和 b ,用异或运算交换它们的值。
思路:
1)中间量t = a^b
2) b = tb,相当于abb,根据异或性质知道ab^b = a,所以b = t^b就是b = a
(异或性质:异或两次不变)
3)a = t^a,道理同上

出现奇数次的数:
题二:输入 n 个数,其中只有一个数出现了奇数次,其它所有数都出现了偶数次。求这个出现了奇数次的数。
思路:
根据异或的性质,两个一样的数异或结果为零。也就是所有出现偶数次的数异或都为零,那么把这 n 个数都异或一下,得到的数就一定是一个出现奇数次的数了。
这里最终偶数次的数异或偶数次的偶数结果为0,0再异或奇数次的数结果为其本身,就是这个道理

编程小号
上一篇 2025-07-04 11:40
下一篇 2025-03-18 16:06

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/135923.html