【蓝桥刷题】备战国赛——异或三角

news2025/1/23 13:15:57

蓝桥杯2021国赛真题——异或三角



🚀 每日一题,冲刺国赛 🚀

在这里插入图片描述



题目导航:

异或三角

在这里插入图片描述


🎇思路:数位 d p dp dp + d f s dfs dfs + 思维

🔱思路分析:

数理基础:

按位异或:一种逻辑运算符,用于比较两个二进制数中每个位的状态,如果两个数的状态不同,则结果为 1 1 1;反之,结果为 0 0 0,其在 p y t h o n python python 语法中表现为 a     ˆ   b a\ \^\ \ b a  ˆ b,在本题中表现为 a ⊕ b a⊕b ab

如:10 ^ 01 = 111100 ^ 1010 = 0110


按位异或的性质:

  1. 恒等律: a     ˆ   0 = a a\ \^\ \ 0 = a a  ˆ 0=a
  2. 归零律: a     ˆ   a = 0 a\ \^\ \ a = 0 a  ˆ a=0
  3. 三元恒等式: a     ˆ   b = c a\ \^\ \ b = c a  ˆ b=c a     ˆ   c = b a\ \^\ \ c = b a  ˆ c=b b     ˆ   c = a b\ \^\ \ c = a b  ˆ c=a

题意分析:而本题其中一个条件即为三个数的异或满足: a ⊕ b ⊕ c = 0 a⊕b⊕c=0 abc=0,因此,对于此类每一个数位上满足某种条件关系的问题,可以用数位 d p dp dp 进行求解

题目要求:

  1. 1 ≤ a , b , c ≤ n 1≤a,b,c≤n 1a,b,cn
  2. a ⊕ b ⊕ c = 0 a⊕b⊕c=0 abc=0
  3. a , b , c a,b,c a,b,c 能组成三角形

step:

🎯1. d f s dfs dfs:

首先,肯定要对二进制的每个数位进行 d f s dfs dfs深搜,从而得到所有可能的情况,因为涉及二进制异或操作 ⊕ ⊕ ,则我们从这个条件出发,由 a ⊕ b ⊕ c = 0 a⊕b⊕c=0 abc=0可知,必有: a ≠ b ≠ c (1) a≠b≠c \tag{1} a=b=c(1)

d e f def def:若存在 a = = b a==b a==b,则 c = a ⊕ b = 0 c=a⊕b=0 c=ab=0,不满足条件

每一个数位上 1 的个数只能为 0 或 2 (2) 每一个数位上1的个数只能为0或2 \tag{2} 每一个数位上1的个数只能为02(2)

d e f def def:若存在 1 1 1个或 3 3 3 1 1 1的情况,则在该数位上三个数异或后为 1 1 1,则结果一定不等于 0 0 0


其次,对于三个数字,我们不可能对每个数字上的每一位进行 d f s dfs dfs,而根据三元恒等式, c = a ⊕ b c=a⊕b c=ab 可以由 a , b a,b a,b 确定,又因为三个数可以按任意顺序排列,所以,我们不妨假设 a a a 为最大数 ( a ∈ [ 1 , n ] ) (a∈[1,n]) (a[1,n]),最后的结果 ∗ 3 *3 3 即可

我们对最大数的二进制数由高位向低位进行枚举,因为需要确定 a , b a,b a,b,我们不妨设二元组 ( a i , b i ) (a_i,b_i) (ai,bi) 表示当前二进制位上 a a a b b b 的值 ( 0 / 1 ) (0/1) 0/1:

根据条件得到选取的二元组与满足条件 a , b , c a,b,c a,b,c 的隐含关系:

  1. a > b a>b a>b ( 1 , 0 ) (1,0) (1,0) 必须出现在 ( 0 , 1 ) (0,1) (0,1) 之前:

( 1 0 ) → ( 0 1 ) (3) \left( \begin{matrix} 1 \\ 0 \end{matrix} \right) → \left( \begin{matrix} 0\\ 1 \end{matrix} \right) \tag{3} (10)(01)(3)

d e f def def:假设 ( 0 , 1 ) (0,1) (0,1)出现在了 ( 1 , 0 ) (1,0) (1,0)之前:
在这里插入图片描述
( 0 , 1 ) (0,1) (0,1) ( 1 , 0 ) (1,0) (1,0)之前,则这两列排列后,b在该数位上的数大于a,此时出现了 b > a b>a b>a 的情况,与假设不符


  1. a > c a>c a>c ( 1 , 1 ) (1,1) (1,1) 必须出现在 ( 0 , 1 ) (0,1) (0,1) 之前:

( 1 1 ) → ( 0 1 ) (4) \left( \begin{matrix} 1 \\ 1 \end{matrix} \right) → \left( \begin{matrix} 0\\ 1 \end{matrix} \right) \tag{4} (11)(01)(4)

d e f def def:假设 ( 1 , 1 ) (1,1) (1,1) 出现在 ( 0 , 1 ) (0,1) (0,1) 之后:
在这里插入图片描述
由于 ( 0 , 1 ) (0,1) (0,1)异或后为1,而 ( 1 , 1 ) (1,1) (1,1)异或后为0,若 ( 1 , 1 ) (1,1) (1,1) ( 0 , 1 ) (0,1) (0,1)后,则对这两列排列后, c c c在该位置的数上大于 a a a,此时,会出现 c > a c>a c>a 的情况,与假设不符


  1. a = b ⊕ c < b + c a=b⊕c<b+c a=bc<b+c:表明必存在状态 ( a i , b i ) = ( 0 , 1 ) (a_i,b_i)=(0,1) (ai,bi)=(0,1)

必有状态 : ( 0 1 ) (5) 必有状态:\left( \begin{matrix} 0 \\ 1 \end{matrix} \right) \tag{5} 必有状态:(01)(5)

d e f def def:由于 b ⊕ c < b + c b⊕c<b+c bc<b+c,则二进制上必定存在某一位使: b i ⊕ c i < b + c b_i⊕c_i<b+c bici<b+c,那么如何实现这一状态呢?其实就是让 a i = 0 , b i = 1 , c i = 1 a_i=0,b_i=1,c_i=1 ai=0,bi=1,ci=1,此时对于加法而言: b i + c i = 2 b_i+c_i=2 bi+ci=2,而对于异或: b i ⊕ c i = 0 b_i⊕c_i=0 bici=0,存在某一位比前者小,也就实现了总体 b ⊕ c < b + c b⊕c<b+c bc<b+c


所以,若满足了上述的 5 5 5个条件,这三个数就是成立的,对于 d f s dfs dfs:

结束条件:若 p o s = 0 pos=0 pos=0且三个状态 ( 1 , 1 ) , ( 1 , 0 ) , ( 0 , 1 ) (1,1),(1,0),(0,1) (1,1)(1,0)(0,1)都出现,cnt+=1

d f s ( p o s , l i m i t , s t a t e s ) dfs(pos,limit,states) dfs(pos,limit,states):

  • p o s pos pos:表示 a a a当前所在的二进制位数
  • l i m i t limit limit:判断前面所选择的数是否全部为上限数
  • s t a t e s states states:判断是否出现过上述三种状态

🎯2. 数位 d p dp dp →记忆化搜索:

对于上述的三个状态,我们只要使其全部出现即为一种结果,因此,我们对状态进行压缩: 1 → ( 0 , 1 ) , 2 → ( 1 , 0 ) , 3 → ( 1 , 1 ) 1→(0,1),2→(1,0),3→(1,1) 1(0,1)2(1,0)3(1,1),再将数字 1 , 2 , 3 1,2,3 1,2,3 进行二进制压缩,则表示为:111,数位为1则代表对应的状态,所以结束条件即为:states=7 (111)

定义 d p dp dp 数组 dp[pos][limit][states]:表示当前数位为 p o s pos pos,前面选择的数状态为 l i m i t ( 0 / 1 ) limit(0/1) limit(0/1),且上述三个二元组的状态为 s t a t e s states states 时, a , b , c a,b,c a,b,c 三个数的选法有多少种

d p dp dp 主要为了 剪枝,增大 d f s dfs dfs在递归时的效率,防止相同的情况下重复计算


完整代码实现:

def dfs(pos,limit,states):
    if pos==0:
        return states==7

    if limit==0 and dp[pos][limit][states]!=-1:
        return dp[pos][limit][states]

    max_num=num[pos] if limit==1 else 1
    res=0
    for i in range(0,max_num+1):
        if i==0: # 如果该位置上ai为0
            # 1.(0,0)
            res+=dfs(pos-1,limit and i==max_num,states)
            # 2.(0,1)
            if states>=6: # 选(0,1)时,(1,1),(1,0)必须要出现
                res+=dfs(pos-1,limit and i==max_num,states|1) # 即为 110^001=111

        elif i==1:
            # 3.(1,0)
            res+=dfs(pos-1,limit and i==max_num,states|2) # x0x|010=x1x
            # 4.(1,1)
            res+=dfs(pos-1,limit and i==max_num,states|4) # 0xx|100=1xx

    if limit==0: # 记忆化搜索
        dp[pos][limit][states]=res
    return res


def solve(n):
    global num
    cnt=0 # 表示当前n的位数
    while n:
        cnt+=1
        num[cnt]=n&1
        n>>=1
    return dfs(cnt,1,0)*3


T=int(input())
num=[0]*32 # 最大为30位数
dp=[[[-1]*8]*2 for _ in range(32)]
for _ in range(T):
    n=int(input())
    print(solve(n))

输出结果:

在这里插入图片描述



🎇此题为2021年国赛数位 d p dp dp题,同时对思维要求也很高,今天的考点是~🎇

数位 d p dp dp + d f s dfs dfs

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

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

相关文章

(2017,AdaIN)用自适应实例归一化进行实时的任意风格迁移

Arbitrary Style Transfer in Real-time with Adaptive Instance Normalization 公众号&#xff1a;EDPJ 目录 ​​​​​​​0. 摘要 1. 简介 2. 相关工作 3. 背景 3.1 批量归一化&#xff08;Batch Normalization&#xff0c;BN&#xff09; 3.2 实例归一化&#xff…

入驻京东直播间、成功借壳上市,交个朋友和时间“交朋友”

交个朋友一直走在“交朋友”的路上。 5月31日晚&#xff0c;交个朋友正式入驻京东直播间&#xff0c;首播销售额超1.5亿元&#xff0c;直播热度榜达人榜第一名&#xff0c;累计访问人次超1700万。据了解&#xff0c;京东618期间&#xff0c;除了日常直播外&#xff0c;交个朋友…

java并发编程:可见性、原子性、有序性三大特性详解

文章目录 可见性导致可见性的原因线程交叉执行重排序结合线程交叉执行共享变量更新后没有及时更新 如何解决可见性问题 原子性出现原子性问题的原因如何解决原子性问题 有序性导致有序性的原因如何解决有序性问题 总结 可见性 内存可见性&#xff0c;指的是线程之间的可见性&am…

IPv6NAT-PT实验:IPv4和IPv6地址转换的配置和验证

IPv6NAT-PT实验&#xff1a;IPv4和IPv6地址转换的配置和验证 【实验目的】 熟悉IPv6NAT-PT的概念。 掌握静态IPv6NAT-PT的配置 掌握动态IPv6NAT-PT的配置。 验证配置。 【实验拓扑】 设备参数如下表所示。 设备 接口 IP地址 子网掩码 默认网关 R1 S0/0 192.168.12…

2023HW护网红队必备工具总结

一、信息收集 1、AppInfoScanner 一款适用于以HVV行动/红队/渗透测试团队为场景的移动端(Android、iOS、WEB、H5、静态网站)信息收集扫描工具&#xff0c;可以帮助渗透测试工程师、红队成员快速收集到移动端或者静态WEB站点中关键的资产信息并提供基本的信息输出,如&#xff…

Java设计模式—模板方法模式

前言&#xff1a;模板方法模式是模板模式的一个具体实现&#xff0c;它定义了一个抽象类&#xff0c;其中包含一个模板方法和若干个基本方法。其中模板方法定义了算法骨架&#xff0c;而基本方法则由子类来实现。因此&#xff0c;模板方法在定义算法的结构方面提供了支持&#…

springMvc 解决 multipart/form-data 方式提交请求 不能获取非文件类型参数的问题和指定springmvc获取静态资源路径

问题&#xff1a; RequestMapping(value "/test",method RequestMethod.POST)ResponseBodypublic String test(String name,String id,MultipartFile file){System.out.println(name);System.out.println(id);System.out.println(file.getOriginalFilename());ret…

onnx模型的修改与调试demo

主要参考&#xff1a; 模型部署入门教程&#xff08;五&#xff09;&#xff1a;ONNX 模型的修改与调试 第五章&#xff1a;ONNX 模型的修改与调试 使用netron 可视化模型 读写onnx 构造onnx 创建一个描述线性函数 output axb 的onnx模型。 需要两个节点&#xff0c;第一个…

造轮子--自己封装一个 start

背景 都说不要造轮子&#xff0c;但是青柠认为&#xff0c;有的时候&#xff0c;造个轮子&#xff0c;更有助于清楚详细的业务逻辑&#xff0c;所以咱也自己写一个轮子&#xff0c;搞个系统开发。大体思路就是先搭建基础框架&#xff0c;然后细写业务逻辑&#xff0c;会涵盖主…

图解HTTP书籍学习2

确保Web安全的HTTPS HTTP的缺点 ●通信使用明文&#xff08;不加密&#xff09;&#xff0c;内容可能会被窃听 ●不验证通信方的身份&#xff0c;因此有可能遭遇伪装 ●无法证明报文的完整性&#xff0c;所以有可能已遭篡改 加密处理防止被窃听 通信的加密 一种方式就是…

【React】类组件,JSX语法,JSX原理,传递参数,条件渲染,列表渲染

❤️ Author&#xff1a; 老九 ☕️ 个人博客&#xff1a;老九的CSDN博客 &#x1f64f; 个人名言&#xff1a;不可控之事 乐观面对 &#x1f60d; 系列专栏&#xff1a; 文章目录 React使用组件&#xff08;类组件&#xff09;JSX语法书写规范JSX插入的内容JSX属性绑定JSX类绑…

前端基础(CSS)——css介绍 常用样式 案例—进化到Bootstrap——进化到Element-UI(未完待续)

目录 引出CSS相关1.css写在哪里&#xff1f;2.css的选择器【重要】&#xff08;1&#xff09;标签选择器---div{}&#xff08;2&#xff09;id选择器----#div01{}&#xff08;3&#xff09;类选择器---class"div01"&#xff0c;.dav01{}&#xff08;4&#xff09;后代…

saas产品私有化(一) 缓存中间件适配

一.背景 名词解释:私有化一般指的是在对客交付过程中,客户由于自身数据敏感,成本控制等原因要求交付乙方将售卖的服务利用现有甲方的硬件设备或者云服务进行服务的部署. 面向场景:一般特制的是saas化的云服务软件提供商的对特殊客群的场景.其中saas行业中比较起步和规模比较大的…

流氓软件篡改微软EDGE浏览器主页面的那些伎俩

微软的EDGE浏览器很好用&#xff0c;但也很容易被绑架&#xff0c;在网上下载各类免费软件&#xff0c;只要你安装完&#xff0c;十有八九就给你把主页改成某某导航了。尽管打开EDGE直接进入360、毒霸、好123等链接对上网影响也不大&#xff0c;打开这些导航页面后&#xff0c;…

IMX6ULL裸机篇之I2C实验主控代码说明二

一. I2C实验 I2C实验内容&#xff1a; 学习如何使用 I.MX6U 的 I2C 接口来驱动 AP3216C&#xff0c;读取 AP3216C 的传感器数据。 I2C读写数据时序图&#xff1a; I2C写数据时序图如下&#xff1a; I2C读数据时序图如下&#xff1a; 二. I2C主控读写时序 1. 读数据与写数…

MMDetection学习记录(二)之配置文件

文件结构 config文件 在 config_base_ 文件夹下有 4 个基本组件类型&#xff0c;分别是&#xff1a;数据集(dataset)&#xff0c;模型(model)&#xff0c;训练策略(schedule)和运行时的默认设置(default runtime)。 命名风格 {model}_[model setting]_{backbone}_{neck}_[no…

微信小程序项目实例——密码管理器

今日推荐&#x1f481;‍♂️ 自疫情后武林广场的音乐喷泉再次开启⛲⛲⛲ 坐在最佳视角下观赏了一场久违的表演&#x1f386;&#x1f386;&#x1f386; &#x1f52e;&#x1f52e;&#x1f52e;&#x1f52e;&#x1f52e;往期优质项目实例&#x1f52e;&#x1f52e;&…

在三台Linux虚拟机上完成构建集群的前置准备

前言 从现在开始进入到实操阶段&#xff0c;将要在VMware软件中创建多台Linux虚拟机&#xff0c;并进行系统设置。 需要同学们拥有前置知识&#xff1a; VMware的使用经验&#xff0c;知道什么是虚拟机并在VMware中创建过Linux虚拟机&#xff08;CentOS系统&#xff09; 熟…

go语言学习——8

文章目录 文件操作打开文件文件读取写文件判读文件或文件夹是否存在拷贝文件统计文件字符命令行参数flag包解析命令行参数 文件操作 os.File封装所有文件相关操作&#xff0c;File是一个结构体 打开文件 package mainimport ("fmt""os" )func main() {file…

重载运算符三个const的作用

const Point operator(const Point &point) const{ } 尝试去理解const,然后搞懂为什么这里放置const。 const 用于修饰其后面跟着的名字&#xff0c;使其为常量&#xff0c;不可被修改。 1.第一个const 的位置后面是函数返回值类型&#xff0c;表明函数返回的是常量&#…