【力扣:1707 1803】0-1字典树

2023-11-26 10:28
文章标签 力扣 字典 1803 1707

本文主要是介绍【力扣:1707 1803】0-1字典树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

思路:树上每个节点存储拥有该节点的数组元素的最小值,left节点表示0,right节点表示1,构建完成后遍历树当子节点没有比mi小的元素时直接输出-1,否则向下构造。

struct tree{int m;tree*left=nullptr,*right=nullptr;tree(int val=INT_MAX):m(val){}
};
class Solution {tree*root=new tree;void add(int val){tree*cur=root;for(int i=31;i>=0;i--){if(1<<i&val){if(!cur->right) cur->right=new tree(val);else cur->right->m=min(val,cur->right->m);cur=cur->right;}else{if(!cur->left) cur->left=new tree(val);else cur->left->m=min(val,cur->left->m);cur=cur->left;}}}int find(int val,int tar){int x=0;tree*cur=root;for(int i=31;i>=0;i--){if(1<<i&val){if(cur->left&&cur->left->m<=tar) x|=1<<i,cur=cur->left;else if(cur->right&&cur->right->m<=tar) cur=cur->right;else return -1;}else {if(cur->right&&cur->right->m<=tar) x|=1<<i,cur=cur->right;else if(cur->left&&cur->left->m<=tar) cur=cur->left;else return -1;}}return x;}
public:vector<int> maximizeXor(vector<int>& nums, vector<vector<int>>& queries) {//sort(nums.begin(),nums.end());for(int i:nums) add(i);vector<int> res;for(auto& i:queries){res.push_back(find(i[0],i[1]));}return res;}
};

在这里插入图片描述

思路:已知nums[i],nums[j]异或值应在[low,high]之间,因而可以转化为小于high的数量减去小于low-1的数量,将问题转化为两个数的异或值小于target的数量,所以树的节点应该记录该节点下元素的数量,然后按位构造当target的此位是0的时候不能构造为1,当target的此位是1时可以构造为0或1,可以直接加上0节点下元素数量,然后向1处接着构造,这样累加之后就得到了异或值小于target的数量

struct tree{int cnt=0;tree*children[2]={nullptr,nullptr};
};
class Solution {tree*root;void add(int val){tree*cur=root;for(int i=31;i>=0;i--){int index=val>>i&1;if(!cur->children[index]) {cur->children[index]=new tree;}cur=cur->children[index];cur->cnt++;}}int find(int val,int m){int x=0;tree*cur=root;for(int i=31;i>=0;i--){int index=val>>i&1;if(m>>i&1){if(cur->children[index]) x+=cur->children[index]->cnt;if(!cur->children[index^1]) return x;cur=cur->children[index^1];}else {if(!cur->children[index]) return x;cur=cur->children[index];}}return x+cur->cnt;}int f(vector<int>& nums,int x){root=new tree;int res=0;for(int i=1;i<nums.size();i++){add(nums[i-1]);res+=find(nums[i],x);}return res;}
public:int countPairs(vector<int>& nums, int low, int high) {return f(nums,high)-f(nums,low-1);}
};

这篇关于【力扣:1707 1803】0-1字典树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/425528

相关文章

POJ2001字典树

给出n个单词,求出每个单词的非公共前缀,如果没有,则输出自己。 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.io.UnsupportedEncodingException;

两数之和--力扣1

两数之和 题目思路C++代码 题目 思路 根据题目要求,元素不能重复且不需要排序,我们这里使用哈希表unordered_map。注意题目说了只对应一种答案。 所以我们在循环中,使用目标值减去当前循环的nums[i],得到差值,如果我们在map中能够找到这个差值,就说明存在两个整数的和为目标值。 如果没有找到,就将当前循环的nums[i]以及下标i放入map中,以便后续查

力扣第347题 前K个高频元素

前言 记录一下刷题历程 力扣第347题 前K个高频元素 前K个高频元素 原题目: 分析 我们首先使用哈希表来统计数字出现的频率,然后我们使用一个桶排序。我们首先定义一个长度为n+1的数组,对于下图这个示例就是长度为7的数组。为什么需要一个长度为n+1的数组呢?假如说总共有三个数字都为1,那么我们需要把这个1放在数组下标为3的位置,假如说数组长度为n,对于这个例子就是长度为3,那么它的

【数据结构与算法 | 灵神题单 | 删除链表篇】力扣3217, 82, 237

总结,删除链表节点问题使用到列表,哈希表,递归比较容易超时,我觉得使用计数排序比较稳,处理起来也不是很难。 1. 力扣3217:从链表中移除在数组中的节点 1.1 题目: 给你一个整数数组 nums 和一个链表的头节点 head。从链表中移除所有存在于 nums 中的节点后,返回修改后的链表的头节点。 示例 1: 输入: nums = [1,2,3], head = [1,2,3,

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

力扣接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]输出:6解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 示例 2: 输入:height

每日一题,力扣leetcode Hot100之238.除自身以外数组的乘积

乍一看这个题很简单,但是不能用除法,并且在O(N)时间复杂度完成或许有点难度。 考虑到不能用除法,如果我们要计算输出结果位置i的值,我们就要获取这个位置左边的乘积和右边的乘积,那么我新设立两个数组L和R。 对于L来说,由于表达的是位置i左边的数的乘积,那么L[0]=1,因为第一个数字左边没数那么为了不影响乘积初始值就设置为1,那么L[1]=L[0]*nums[0],那么L[i]=L[i-1

python 实现第k个字典排列算法

第k个字典排列算法介绍 "第k个字典排列"算法通常指的是在给定的字符集合(例如,字符串中的字符)中,找到所有可能排列的第k个排列。这个问题可以通过多种方法解决,但一个常见且高效的方法是使用“下一个排列”算法的变种,或称为“第k个排列”的直接算法。 方法一:使用“下一个排列”的变种 生成所有排列:首先生成所有排列,但显然这种方法对于较大的输入集合是不切实际的,因为它涉及到大量的计算和存储。 排序

力扣 797. 所有可能路径【DFS】

1. 题目 2. 代码 DFS , 直接见代码 class Solution {public:vector<int> path;vector<vector<int>> res; // 结果集void dfs(vector<vector<int>>& graph, int cur, int n){// 找出所有从节点 0 到节点 n-1 的路径// 下标从 0 开始的if (

POJ3617(字典序最小问题)

书中43页 此题有坑点,PE了40分钟.也是醉了....题目要求每80个字符才换行,而且最后一个如果恰好就不用换,这不是无聊嘛....... #include <iostream>#include <cstdio>#include <cstring>using namespace std;int n,m;char S[2100],P[2100];int main(){#ifd