枚举二进制数的子集

news2025/1/9 2:58:48

思想:

如1011的二进制子集有1011,1010,1001,1000,0011,0010,0001,0000

思想是每次对当前最小子元素-1与目标x取与运算。枚举到0为止。

  1. 成立原因:因为我们是由大到小,如果是每次减一不取与(&),显然枚举x次可以找到所有子集。
  2. 而与运算就是缩减了这部分时间,你每次减一后,如果当前数>下一个目标子元素,&x进行了一些删除操作(删除了当前数~下一个目标子元素中间的数)
  3. 考虑他们为什么会被删除吧,因为他们二进制上有1而x却没1,只有这个原因,如果你有的1x都有,你是不会被删除的,所以删除的都是非子集。又因为是逐步-1直到0,所以可以快速枚举所有子集。
		for(int j=i; ; j=(j-1)&i)//枚举二进制子集
				{
					cnt[i].push_back(j);
					if(!j)break;
				}

一道例题:Problem - 5648 (hdu.edu.cn)

思路:

  1. 直枚举接计算i,j发现会重复计算多次相同的a,b(设a=i&j,b=i|j),所以我们考虑计算每组(a,b)然后算贡献。

  2. 我们先默认n>m(毕竟前后都一样),那么所有数len<log2n<14(即a,b都是二进制不超过14位的),如果枚举a,b二进制的组合,情况有3^len<3^14=4782969<5e6,暴力dfs可以接受。

  3. 显然,a是b的子集,那么b-a就是i与j不是一起出现的二进制上的1组成的数,所以b-a的二进制的子集就是i,j可以取到的所有组合情况,如b-a=(0101)_{2},那么可以是i=a+(0000),j=a+(0101)或者i=a+(0001),j=a+(0100),或者i=a+(0100),j=a+(0001)或者i=a+(0101),j=a+(0000)。

  4. 注意到有一个数(i,j谁都可以啦)要<=m,所以我们可以取b-a的子集中<=m-a的元素,这些元素的个数*gcd就是该(a,b)组合产生的贡献。

  5. 等等,还不行吧?注意到,可以取的子集也有下限,即你如果i取了x,那么j要取b-x,所以i=a+x,j=a+b-x,要同时满足1<=i,j<=n,所以a+b-x<=n,即下限是x>=b-n。

  6. 上面都说了i,j都要>=1,如果a=0,那么b取子集0000不就炸了吗(a+(0000)=0<1).所以特判以下,a=0,增添上下限,x至少>=1,至多<=b-1(至少留一个1给另一个)

#include <bits/stdc++.h>
using namespace std;
#define ll               long long
#define endl             "\n"
#define int              long long
const int N = 2e4 + 10;
int len,ans,n,m;;
vector<int>cnt[N];
int tocnt(int x,int val)//upper_bound返回所有小于等于val个数的子集
{
	return upper_bound(cnt[x].begin(),cnt[x].end(),val)-cnt[x].begin();
}

void dfs(int pos,int a,int b)
{
	if(pos==len)
		{
			int sum=b-a,l=b-n,r=m-a;
			if(!a)l=max(1ll,l),r=min(r,b-1);
			if(l>r)return;
			ans+=__gcd(a,b)*(tocnt(sum,r)-tocnt(sum,l-1));//划分上下限求贡献
			return;
		}
	dfs(pos+1,a,b);
	dfs(pos+1,a,b|(1<<pos));
	if((a|(1<<pos))<=m)dfs(pos+1,a|(1<<pos),b|(1<<pos));//dfs枚举a,b组合情况
}
void mysolve()
{
	cin>>n>>m;
	if(n<m)swap(n,m);
	len=ans=0;
	while((1<<len)<=n)len++;//取二进制最长长度
	for(int i=0; i<(1<<len); ++i)
		{
			cnt[i].clear();
			for(int j=i; ; j=(j-1)&i)//枚举二进制子集
				{
					cnt[i].push_back(j);
					if(!j)break;
				}
			sort(cnt[i].begin(),cnt[i].end());//排序使后面可以二分
		}
	dfs(0,0,0);
	cout<<ans<<endl;
}

int32_t main()
{
	std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	ll t=1;
	cin >> t;
	while (t--)
		{
			mysolve();
		}
	system("pause");
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/478430.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python使用AI photo2cartoon制作属于你的漫画头像

Python使用AI photo2cartoon制作属于你的漫画头像 1. 效果图2. 原理3. 源码参考 git clone https://github.com/minivision-ai/photo2cartoon.git cd ./photo2cartoon python test.py --photo_path images/photo_test.jpg --save_path images/cartoon_result.png1. 效果图 官方…

计算机组成原理 存储器(下)

Cache和主存之间的映射: Cache的基本结构 Cache存储体以块为单位和主存交换信息&#xff0c;地址变换机制是由CPU送往主存的数据转换为Cacche的地址&#xff0c;主存和Cache的大小相同所以 &#xff0c;如果能够建立对应关系&#xff0c;则代表命中。 Cache的读写操作 写操作…

链表:常见面试题-根据大小划分区域

将单向链表按某值划分为左边小、中间相等、右边大的形式 1&#xff09;将链表放入数组里&#xff0c;在数组上做partition&#xff08;类似快排&#xff09;&#xff0c;这是笔试时推荐的写法 2&#xff09;分为小、中、大三部分&#xff0c;再把各个部分之间串起来&#xff…

1. 异常概述

目录 1.1 什么是生活的异常 1.2 什么是程序的异常 1.3 异常的抛出机制 1.4 如何对待异常 1.1 什么是生活的异常 男主角小明每天开车上班&#xff0c;正常车程 1 小时。但是&#xff0c;不出意外的话&#xff0c;可能会出现意外。 出现意外&#xff0c;即为异常情况。我们会…

自动化测试和selenium的使用

目录 自动化测试定义 为什么选择selenium来作为我们web自动化测试的工具&#xff1f; 自动化测试定位元素 使用cssSelector定位 使用XPath 定位 操作测试对象 模拟手动从键盘输入 点击对象 获取页面文本 清除对象输入的文本内容 添加等待&#xff08;三种方式&#…

00 SQL介绍

什么是SQL Structured Query Language&#xff1a;结构化查询语言 其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式可能会存在一些不一样的地方&#xff0c;我们称为“方言”。 SQL通用语法 SQL 语句可以单行或多行书写&#xff0c;以分号结尾。 可使用空…

干货 | 如何让Zotero更加强大?这六个插件是您的不二之选!

Hello,大家好&#xff01; 这里是壹脑云科研圈&#xff0c;我是喵君姐姐~ Zotero是由安德鲁w梅隆基金会斯隆基金会以及美国博物馆和图书馆服务协会资助开发&#xff0c;是一个免费易用的文献管理软件&#xff0c;可协助我们收集、管理及引用研究资源&#xff0c;包括期刊、书籍…

系统集成项目管理工程师 笔记(第20章:知识产权管理、第21章:法律法规和标准规范)

文章目录 20.1.2 知识产权的特性 58420.2.1 著作权及邻接权 58520.2.2 专利权 58920.2.3 商标权 59221.3 诉讼时效 59921.6.3 标准分级与标准类型 60321.7.2 信息系统集成项目管理常用的技术标准 6061、基础标准2、开发标准3、文档标准4、管理标准 第20章 知识产权管理 584 20.…

LeetCode刷题系列之----->(指针玩转链表篇)(三)

&#x1f349;博客主页&#xff1a;阿博历练记 &#x1f4d6;文章专栏&#xff1a;数据结构与算法 &#x1f50d;代码仓库&#xff1a;阿博编程日记 &#x1f339;欢迎关注&#xff1a;欢迎友友们点赞收藏关注哦 文章目录 &#x1f58b;1.题目描述&#x1f4a1; 逻辑分析&#…

Java+Selenium常用方法梳理

五一假期&#xff0c;祝大家节日快乐。本篇继续自动化测试知识梳理。selenium 自己封装好用的方法&#xff0c;如悬停&#xff0c;句柄获取&#xff0c;可直接调用&#xff0c;实现自己的需求。 1、多窗口切换 即获取页面的句柄&#xff0c;来实现页面的切换&#xff0c;以ha…

GC日志分析工具一GCview使用介绍

目录 一、GCViewer介绍 二、GCViewer 使用 2.1 编译 2.2 使用 一、GCViewer介绍 业界较为流行分析GC日志的两个工具——GCViewer、GCEasy。GCEasy部分功能还是要收费的&#xff0c;今天笔者给大家介绍一下GCViewer的使用与功能点。Memory Analyzer Mat JVM 分析 二、GCVi…

Msfconsole使用永恒之蓝入侵Win7并上传执行可执行文件

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、信息收集二、开始入侵1.启动msfconsole2.搜索漏洞3.文件上传其他 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 我昨天我测…

初识springframework

目录 一.框架的概念&#xff1a; 1.什么是框架&#xff1f; 2.框架的作用&#xff1f; 二.springframework-core(bean容器) 1.什么是bean容器&#xff1f; 对bean容器的理解&#xff08;M&#xff09; 对IOC和DI的理解&#xff08;M&#xff09; DI的底层实现原理是依赖…

Linux:网络套接字

理解源IP地址和目的IP地址 在IP数据包头部中, 有两个IP地址, 分别叫做源IP地址, 和目的IP地址. 思考: 我们光有IP地址就可以完成通信了嘛? 想象一下发qq消息的例子, 有了IP地址能够把消息发送到对方的机器上, 但是还需要有一个其他的标识来区分出, 这个数据要给哪个程序进行…

@Autowired和@Resource注解之间的关系区别,Bean的作用域和生命周期,Spring的执行流程

目录 一. Autowired 和 Resource 注解 二. Bean的作用域 1. singleton(单例模式) 2. prototype(原型模式)(多例模式) 3. 请求作用域&#xff1a;request 4. 会话作用域&#xff1a;session 三. Spring 的执行流程 四. Bean 的生命周期 1. 实例化 2. 设置属性 3. Bea…

【数据结构初阶】环形链表

目录 一、判断链表中是否存在环思路分析 二、求环的长度三、求入环点 一、判断链表中是否存在环 题目链接&#xff1a; 判断链表中是否存在环 思路 把它转换为追击问题&#xff08;快慢指针&#xff09; 快指针比慢指针多走一步&#xff0c;当快指针正好进入环时&#xff0c;慢…

脑科学数据挖掘论文精读系列(1)【抑郁对大脑神经影响和对脊椎损伤患者运动恢复的影响探究】

Depression mediated the relationships between precentral-subcortical causal links and motor recovery in spinal cord injury patients 手动防爬虫&#xff0c;原创作者CSDN&#xff1a;总是重复名字我很烦啊&#xff0c;联系邮箱daledeng123163.com直达原文 这是一篇收…

操作系统——操作系统用户界面

0.关注博主有更多知识 操作系统入门知识合集 目录 3.1操作系统启动过程 3.1.1BIOS和主引导记录MBR 思考题&#xff1a; 3.1.2操作系统的启动过程 思考题&#xff1a; 3.2用户界面 3.2.1用户界面概念 思考题&#xff1a; 3.2.2系统调用 3.1操作系统启动过程 3.1.1BIO…

【五一创作】使用Resnet残差网络对图像进行分类(猫十二分类,模型定义、训练、保存、预测)(一)

使用Resnet残差网络对图像进行分类 &#xff08;猫十二分类&#xff0c;模型定义、训练、保存、预测&#xff09;(一&#xff09; 目录 一、项目简介 二、环境说明 1、安装库 2、导入需要的库 三、分类过程 &#xff08;1&#xff09;、解压数据集 &#xff08;2&#xf…

Spring中的Bean

1. Bean的配置 Spring 可以被看作是一个大型工厂&#xff0c;这个工厂的作用就是生产和管理 Spring 容器中的Bean。如果想要在项目中使用这个工厂&#xff0c;就需要开发者对Spring 的配置文件进行配置。 Spring 容器支持XML 和 Properties 两种格式的配置文件&#xff0c;在实…