备战蓝桥杯---搜索(进阶3)

news2024/9/24 7:16:38

看一道比较难又有趣的题:

下面是分析:

我们不妨把属性值看成点,一个装备可以看成一条边(只能选一个端点)不存在有装备属性值的当成一个点,于是我们便形成了树或图,如果是树的话,有一个点不能选,如果有>=n条边,则都可以选。

因此,我们从1的开始,如果不能全选就不选最大的,我们for出不能的最小值,答案就是减1。

那如何判断边呢,我们采用并查集或直接搜索。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int n,a[100100],x,y,m,max1;
vector<int> tu[1000020];
int dfs(int x,int fa){
    max1=max(x,max1);
    a[x]=1;
    int f=0;
    for(int i=0;i<tu[x].size();i++){
        if(fa==tu[x][i]) continue;
        if(a[tu[x][i]]==1){
            f=1;
            continue;
        }
        if(dfs(tu[x][i],x)==1) f=1;
    }
    return f;
}
int main(){
    cin>>n;
    for(int i=1;i<=n;i++){
        scanf("%d%d",&x,&y);
        tu[x].push_back(y);
        tu[y].push_back(x);
        m=max(m,x);
        m=max(m,y);
    }
    int ans=m+1;
    for(int i=1;i<=m;i++){
        if(a[i]==1) continue;
        max1=0;
        if(dfs(i,0)==1) continue;
        else ans=min(ans,max1);
    }
    cout<<ans-1;
}

下面是用并查集实现:

#include<bits/stdc++.h>
using namespace std;
int n,fa[10010],x,y,m,max1[10010],b[10010],mm;
int find(int x){
    if(fa[x]==x) return x;
    else return fa[x]=find(fa[x]);
}
int main(){
    cin>>n;
    for(int i=1;i<=10000;i++){
        max1[i]=i;
        b[i]=0;
        fa[i]=i;
    } 
    for(int i=1;i<=n;i++){
        scanf("%d%d",&x,&y);
        int x1=find(x);
        int y1=find(y);
        if(x1==y1){
            b[x1]=1;
        }
        else{
            fa[x1]=y1;
            max1[y1]=max(max1[x1],max1[y1]);
            b[y1]=(b[y1]||b[x1]);
        }
        mm=max(mm,x);
        mm=max(mm,y);
    }
    int ans=mm+1;
    for(int i=1;i<=mm;i++){
        if(fa[i]==i){
            if(b[i]==0){
                ans=min(ans,max1[i]);
            }
        }
    }
    cout<<ans-1;
}

再看个整体二分的题:

2^24虽然可以但很慢,于是我们考虑用整体二分的思想+用0/1串存每一个字母来解决:

他们对应的二进制异或和为0.

因此,我们对前12个暴力枚举,然后再对后面几个暴力枚举,再看看原来集合里是否有相同的值,有的话就记录个数,用map存,复杂度为2^2/n*logn,取max即可。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int n,a[30],ans;
map<int,int> mp1;
map<int,int> mp2;
string s[30];
void dfs(int begin,int end,int tmp,int xuan,int biao){
	if(begin>end){
		if(biao==1){
		if(mp1.count(tmp)==0) mp1[tmp]=xuan;
		else{
			mp1[tmp]=max(mp1[tmp],xuan);
		}}
		else{
			if(mp2.count(tmp)==0) mp2[tmp]=xuan;
		else{
			mp2[tmp]=max(mp2[tmp],xuan);
		}	
		}
		return;
	}
	int tt=tmp^a[begin];
	dfs(begin+1,end,tt,xuan+1,biao);
	dfs(begin+1,end,tmp,xuan,biao);
	return;
}
int main(){
	while(cin>>n){
		ans=0;
		mp1.clear();
		mp2.clear();
		memset(a,0,sizeof(a));
		for(int i=1;i<=n;i++){
			cin>>s[i];
			for(int j=0;j<s[i].length();j++){
				a[i]^=1<<(s[i][j]-'A');
			}
		}
		dfs(1,n/2,0,0,1);
		dfs(n/2+1,n,0,0,2);
		for(map<int,int>::iterator it=mp2.begin();it!=mp2.end();it++){
			if(mp1.count(it->first)!=0) ans=max(ans,mp1[it->first]+it->second);
		}
		if(mp1.count(0)!=0) ans=max(ans,mp1[0]);
		if(mp2.count(0)!=0) ans=max(ans,mp2[0]);
		printf("%d\n",ans);
	}
}

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

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

相关文章

请立即收藏!春节必备AI工具盘点:一键拜年短信、海报!AI全家福!

大家好&#xff0c;我是木易&#xff0c;一个持续关注AI领域的互联网技术产品经理&#xff0c;国内Top2本科&#xff0c;美国Top10 CS研究生&#xff0c;MBA。我坚信AI是普通人变强的“外挂”&#xff0c;所以创建了“AI信息Gap”这个公众号&#xff0c;专注于分享AI全维度知识…

Maven之安装自定义jar到本地Maven仓库中

Maven之安装自定义jar到本地Maven仓库中 文章目录 Maven之安装自定义jar到本地Maven仓库中1. 命令行窗口安装方式1. 常用参数说明2. 安装实例 2. IDEA中安装方式3. 使用 1. 命令行窗口安装方式 安装指定文件到本地仓库命令&#xff1a;mvn install:install-file; 在windows的cm…

iOS 需求 多语言(国际化)App开发 源码

一直觉得自己写的不是技术&#xff0c;而是情怀&#xff0c;一个个的教程是自己这一路走来的痕迹。靠专业技能的成功是最具可复制性的&#xff0c;希望我的这条路能让你们少走弯路&#xff0c;希望我能帮你们抹去知识的蒙尘&#xff0c;希望我能帮你们理清知识的脉络&#xff0…

正点原子--STM32基本定时器学习笔记(2)

目录 1. 相关寄存器介绍 1.1 控制寄存器 1(TIMx_CR1)​编辑 1.2 DMA/中断使能寄存器(TIMx_DIER) 1.3 状态寄存器(TIMx_SR) 1.4 计数器(TIMx_CNT) 1.5 预分频器(TIMx_PSC) 1.6 自动重装载寄存器(TIMx_ARR) 2. 工程建立 3. 导入tim.c文件 4. 相关HAL库函数介绍 4.1 H…

购物车商品数量为0判断是否删除

当编辑商品的数量为1&#xff0c;再减的话&#xff0c;我们搞个模态提示&#xff0c;让用户决定是否要删除这个商品&#xff1f; //商品数量的编辑功能handleItemNumEdit(e){const {operation,id}e.currentTarget.dataset;console.log(operation,id);let {cart}this.data;let …

13. UE5 RPG限制Attribute的值的范围以及生成结构体

前面几章&#xff0c;我们实现了通过GameplayEffect对Attribute值的修改&#xff0c;比如血量和蓝量&#xff0c;我们都是有一个最大血量和最大蓝量去限制它的最大值&#xff0c;而且血量和蓝量最小值不会小于零。之前我们是没有实现相关限制的&#xff0c;接下来&#xff0c;我…

3.1-媒资管理之需求分析+搭建Nacos

文章目录 媒资管理模块1 模块需求分析1.1 模块介绍1.2 业务流程1.2.1 上传图片1.2.2 上传视频1.2.3 处理视频1.2.4 审核媒资 2.2 搭建Nacos2.2.1 服务发现中心2.2.2 配置中心2.2.2.1 配置三要素2.2.2.3配置content-api 2.2.3 公用配置2.2.4 配置优先级2.2.5 导入配置文件2.2.6 …

三、设计模式相关理论总结

一、面向对象编程 1.1 概述 简称Object Oriented Program(OOP)&#xff0c;指以类或对象作为基础组织单元&#xff0c;遵循封装、继承、多态以及抽象等特性&#xff0c;进行编程。其中面向对象不一定遵循封装、继承、封装和多态等特性&#xff0c;只是前人总结的套路规范&…

前端JavaScript篇之对闭包的理解

目录 对闭包的理解用途循环中使用闭包解决 var 定义函数的问题 对闭包的理解 闭包是指一个函数能够访问并操作其词法作用域&#xff08;定义时所在的作用域&#xff09;之外的变量的能力。它可以通过在一个函数内部创建另一个函数来实现。内部函数可以访问外部函数的局部变量、…

Python算法题集_两数相加

Python算法题集_两数相加 题2&#xff1a;两数相加1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【直接相加】2) 改进版一【对齐链表】3) 改进版二【数组求和】 4. 最优算法 本文为Python算法题集之一的代码示例 题2&#xff1a;两数相加 1.…

相机图像质量研究(10)常见问题总结:光学结构对成像的影响--光圈

系列文章目录 相机图像质量研究(1)Camera成像流程介绍 相机图像质量研究(2)ISP专用平台调优介绍 相机图像质量研究(3)图像质量测试介绍 相机图像质量研究(4)常见问题总结&#xff1a;光学结构对成像的影响--焦距 相机图像质量研究(5)常见问题总结&#xff1a;光学结构对成…

Quicker读取浏览器的书签(包括firefox火狐)

从edge换了火狐&#xff0c;但是quicker不能读取本地的bookmarks文件了&#xff0c;就研究了一下。 方法1&#xff1a;读取本地Bookmarks文件&#xff08;仅谷歌内核浏览器&#xff09; 谷歌内核的浏览器本地会有Bookmarks文件&#xff0c;放了所有的书签数据&#xff0c;直接…

我的docker随笔43:问答平台answer部署

本文介绍开源问答社区平台Answer的容器化部署。 起因 笔者一直想搭建一个类似stack overflower这样的平台&#xff0c;自使用了Typora&#xff0c;就正式全面用MarkdownTyporagit来积累自己的个人知识库&#xff0c;但没有做到web化&#xff0c;现在也还在探索更好的方法。 无…

MyBatisPlus基础操作之增删改查

目录 一、基本使用 1.1 插入数据 1.2 删除操作 1.3 更新操作 二、条件构造器Wrapper 2.1 常用AbstractWrapper方法 2.1.1 示例一 2.2.2 示例二 2.2.3 示例三 2.2 常用QueryWrapper方法 2.2.1 示例一 2.2.2 示例二 2.2.3 示例三&#xff08;常用&#xff09; 2.3 常…

PgSQL技术内幕 - case when表达式实现机制

PgSQL技术内幕 - case when表达式实现机制 CASE表达式如同 C语言中的if/else语句一样&#xff0c;为SQL添加了条件逻辑处理能力&#xff0c;可以根据不同条件返回不同结果。PgSQL支持两种语法&#xff1a;简单表达式和搜索表达式。 1、搜索表达式 语法如下&#xff1a; CASE WH…

android studio下开发flutter

文章目录 1. 配置环境 https://flutter.cn/docs/get-started/install2. android studio下开发flutter 1. 配置环境 https://flutter.cn/docs/get-started/install 2. android studio下开发flutter 打开Android Studio -> File -> Settings -> Plugins 搜索Dart插件 …

java_error_in_pycharm.hprof文件是什么?能删除吗?

java_error_in_pycharm.hprof文件是什么&#xff1f;能删除吗&#xff1f; &#x1f335;文章目录&#x1f335; &#x1f333;引言&#x1f333;&#x1f333;hprof格式文件介绍&#x1f333;&#x1f333;java_error_in_pycharm.hprof文件什么情况下能删除&#x1f333;&…

简化版SpringMVC

简化版SpringMVC web.xml xml version"1.0" encoding"UTF-8"?> <web-app version"2.5" xmlns"http://java.sun.com/xml/ns/javaee" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation&quo…

科技王座“座次变更”:英伟达超越亚马逊在即,距离谷歌也不远

英伟达的市值即将超过亚马逊&#xff0c;为二十年来首次。 截至2月7日收盘&#xff0c;英伟达市值达到1.73万亿美元&#xff0c;逼近亚马逊1.77万亿美元的市值&#xff0c;距离谷歌1.82万亿美元的市值也不远。 对人工智能的热情推升英伟达的股价去年以来一路飙涨&#xff0c;受…

【开源】基于JAVA+Vue+SpringBoot的新能源电池回收系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 用户档案模块2.2 电池品类模块2.3 回收机构模块2.4 电池订单模块2.5 客服咨询模块 三、系统设计3.1 用例设计3.2 业务流程设计3.3 E-R 图设计 四、系统展示五、核心代码5.1 增改电池类型5.2 查询电池品类5.3 查询电池回…