The XOR Largest Pair(tire樹)

来源:https://www.cnblogs.com/lykkk/archive/2019/07/27/11256831.html
-Advertisement-
Play Games

題目 "The XOR Largest Pair" 解析 一年前聽學長講這道題,什麼01trie,好高級啊,所以沒學,現在一看。。。。 看到xor就應該想到二進位,一看數據$A_i using namespace std; const int N = 4e6 + 10; int n, a, num, ...


題目

The XOR Largest Pair

解析

一年前聽學長講這道題,什麼01trie,好高級啊,所以沒學,現在一看。。。。
看到xor就應該想到二進位,一看數據\(A_i< 2^{31}\),考慮把所有的數都處理成長度為32的二進位數,插入字典樹中,查詢的時候就逐位比較,有不同的先走不同的那邊,這樣保證了每次插入一個數時查詢的結果是最大的,然後不斷更新最大值就可以了
我這種不用位運算的懶人就直接用bitset維護了
從高位到地位插入可能好算一些

代碼

#include <bits/stdc++.h>
using namespace std;
const int N = 4e6 + 10;

int n, a, num, ans;

struct node {
    int nx[2];
} e[N];

void insert(int n) {
    bitset<35>s(n);
    int rt = 0;
    for (int i = 30; i >= 0; --i) {
        int v = (int)s[i];
        if (!e[rt].nx[v]) e[rt].nx[v] = ++num;
        rt = e[rt].nx[v];
    }
}

int query(int x) {
    bitset<35>s(x);
    int rt = 0, ret = 0;
    for (int i = 30; i >= 0; --i) {
        int v = (int)s[i];
        if (e[rt].nx[v ^ 1]) ret = ret << 1 | 1, rt = e[rt].nx[v ^ 1];
        else ret <<= 1, rt = e[rt].nx[v];
    }
    return ret;  
}

int main() {
    cin >> n;
    for (int i = 1, x; i <= n; ++i) {
        cin >> x;
        ans = max(ans, query(x));
        insert(x);
    }
    cout << ans;
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 配置JMX遠程連接 1. 配置啟動參數 啟動jar時,添加如下配置 啟動參數說明 1. :配置一個遠程伺服器上未被占用的埠 2. :配置 JMX 是否啟用 ssl 3. :配置 JXM 是否啟動鑒權 4. :配置伺服器 IP 2. 配置 jvisualvm 添加遠程主機信息,填寫主機名,埠。埠 ...
  • 午休後,看看電視,在回顧下新的知識 函數。相信很多小伙伴在學習python後 ,學到函數就會有一部分人放棄了,從努力到放棄(內容過於真實) 好希望我也能有很多粉絲,hhh.... 函數: 什麼是函數?作用是什麼呢? 函數就是讓我們來偷懶的,沒錯,就是這樣簡單粗暴的解釋。。。 作用呢?就是我們定義的函 ...
  • 1.變數的輸入: input函數: input() input("請輸入銀行卡密碼") password = input("請輸入銀行卡密碼") 變數名 = input("XXX") # 用輸入函數給變數賦值 輸入函數給變數賦值舉例: 註:所有input()得到的數據類型都是str字元串類型 2.變 ...
  • 輸出函數是最常用的,對print()參數的準確認識尤為重要。 sep='':sep參數表示函數中不同value的分隔符,預設為一個空格。 end='':end參數表示函數結尾的處理,預設換行。 例如: ...
  • Swing的輸入框仍然分成兩類:單行輸入框和多行輸入框,但與AWT的同類控制項相比,它們在若幹細節上有所調整。首先說單行輸入框,AWT的單行輸入框名叫TextField,平時輸入什麼字元它便顯示什麼字元,可一旦調用了setEchoChar方法設置回顯字元,TextField馬上變成只顯示密文字元了。然 ...
  • 在使用Visual C++ 6.0打開文件時可能會出現下麵的情況 這可能是Vc6.0和win7相容性問題。 方法: 下載filetool即可 鏈接:https://pan.baidu.com/s/1Xmx0XI0Dy9uZGJEQW4cHQg 提取碼:drgz 下載之後,解壓到一個目錄,我這個是解壓 ...
  • 關於python單例模式是什麼,以及一些實現方法的整理與講解。 ...
  • 今天在刷題的時候用到了正則,用的過程中就感覺有點不太熟練了,很久沒有用正則都有點忘了。所以現在呢,我們就一起來review一下python中正則模塊re的用法吧。 今天是review,所以一些基礎的概念就不做介紹了,先來看正則中的修飾符以及它的功能: 修飾符 re.I 使匹配對大小寫不敏感 re.L ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...