文巾解题 leetcode1442. 形成两个异或相等数组的三元组数目

1 题目描述

2 知识点补充(异或运算)

还有一条结论,是这道题比较重要的一个结论,就是  a^b=a^c ->b=c

这个结论是可以说明的,我们记a^b=a^c=x,则有b=c=a^x

3 解题思路

回到本题,我们可以设计一个这样的数组

 

可以进一步化简为

 

所以题目中的a和b可以表示为

若a=b,那么

3-1 方法1 三重循环(循环i,j,k)

class Solution:
    def countTriplets(self, arr: List[int]) -> int:
        tmp=[0]
        for i in range(len(arr)):
            tmp.append(tmp[-1]^arr[i])
        ret=0
        for i in range(1,len(arr)):
            for j in range(i+1,len(arr)+1):
                for k in range(j,len(arr)+1):
                    if(tmp[i-1]==tmp[k]):
                        ret+=1
        return(ret)

3-2 方法2 二重循环

当 Si=Sk+1的时候,[i+1,k]之间任意的j都是合理的,所以我们只需要枚举下标i和k就可以了


class Solution:
    def countTriplets(self, arr: List[int]) -> int:
        tmp=[0]
        for i in range(len(arr)):
            tmp.append(tmp[-1]^arr[i])
        ret=0
        for i in range(1,len(arr)):
            for j in range(i+1,len(arr)+1):
                #for k in range(j,len(arr)+1):
                    if(tmp[i-1]==tmp[j]):
                        ret+=j-i
        return(ret)

3-3 方法3 一重循环

更简化的是,我们在构建数组S的时候,就可以计算次数了,这样两个循环又并成了一个循环

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UQI-LIUWJ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值