codeforces 484A bits

本文深入探讨了二进制位操作的高级应用,通过具体的C++代码示例,讲解了如何使用位掩码(bitmasks)进行高效的数据处理。特别关注了位操作中的置位(set bit)技巧,以及如何在循环中利用这一特性找到最优解。

添加链接描述
在这里插入图片描述
bitmasks
太强了太强了太强了,二进制收下我的膝盖!

#include<bits/stdc++.h>
using namespace std;
int main()
{
	
	int t;
	cin >> t;
	while (t--) {
		long long a, b, k;
		cin >> a >> b;
		k = a;
		for (int i = 0; i < 64; i++) {
			a |= 1ll<< i;				//把a的第 i 位(从右数起bai) 置1     相当于 a= a | (1ll<<i);					
			if (a > b)					//								|= &= 和+= -= 一样,运算一样
				break;
			
			else if (a > k)
				k = a;
				
		}
		cout << k << "\n";
	}
/*
	long long a;
	a = 1LL << 60;					//注意:这里LL 或者 ll 都是把int转化成long long, 只能写LL 或ll,而且位置必须固定在这里
	cout << a << "\n";
	*/
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值