[SCOI2016] 幸運數字

来源:https://www.cnblogs.com/nosta/archive/2018/12/26/10181865.html
-Advertisement-
Play Games

利用線性基的合併,(直接暴力合併,複雜度62^2),當樹上路徑和來做,仿造java風格寫個類就好。。。(然後跑的巨慢,但是可以優化哈哈) cpp include using namespace std; const int N=2e4+7; / 我突然覺得,應該寫一個類。。 / struct Sha ...


利用線性基的合併,(直接暴力合併,複雜度62^2),當樹上路徑和來做。。。(然後跑的巨慢,但是可以優化哈哈)

#include <bits/stdc++.h>
using namespace std;

const int N=2e4+7;

struct XianXingJi {
    long long base[64];
    inline bool insert(long long vec) {
        for(int i=62; ~i; --i) {
            if(!(vec>>i)) continue;
            if(!base[i]) {base[i]=vec; return 1;}
            vec^=base[i];
        }
        return 0;
    }
    inline XianXingJi add(const XianXingJi& d) {
        XianXingJi res=*this;
        for(int i=62; ~i; --i) {
            if(d.base[i]) res.insert(d.base[i]);
        }
        return res;
    }
    inline long long max() {
        long long res=0;
        for(int i=62; ~i; --i) {
            if((res^base[i])>res) res^=base[i];
        }
        return res;
    }
} dis[N][20];

int n,m;
int fa[N][20],dep[N];
vector<int> e[N];

void pre(int x,int pa) {
    dep[x]=dep[fa[x][0]=pa]+1;
    for(int i=1; (1<<i)<=dep[x]; ++i) {
        fa[x][i]=fa[fa[x][i-1]][i-1];
        dis[x][i]=dis[x][i-1].add(dis[fa[x][i-1]][i-1]);
    }
    for(int y:e[x]) if(y!=pa) {
        pre(y,x);
    }
}
long long query(int x,int y) {
    XianXingJi res;
    memset(&res,0,sizeof res);
    if(dep[x]<dep[y]) swap(x,y);
    int dif=dep[x]-dep[y];
    for(int i=19; ~i; --i) {
        if(dif&(1<<i)) {
            res=res.add(dis[x][i]), x=fa[x][i];
        }
    }
    if(x==y) return res.add(dis[x][0]).max();
    for(int i=19; ~i; --i) {
        if(fa[x][i]!=fa[y][i]) {
            res=res.add(dis[x][i]), x=fa[x][i];
            res=res.add(dis[y][i]), y=fa[y][i];
        }
    }
    res=res.add(dis[x][0]).add(dis[y][1]);
    return res.max();
}

int main() {
    scanf("%d%d",&n,&m);
    for(int i=1; i<=n; ++i) {
        long long x;
        scanf("%lld",&x);
        dis[i][0].insert(x);
    }
    for(int i=n,x,y; --i; ) {
        scanf("%d%d",&x,&y);
        e[x].push_back(y);
        e[y].push_back(x);
    }
    pre(1,0);
    for(int i=m,x,y; i--; ) {
        scanf("%d%d",&x,&y);
        printf("%lld\n",query(x,y));
    }
    return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • 前言 本篇緊接著spring入門詳細教程(二),建議閱讀本篇前,先閱讀第一篇和第二篇。鏈接如下: Spring入門詳細教程(一) https://www.cnblogs.com/jichi/p/10165538.html Spring入門詳細教程(二) https://www.cnblogs.com ...
  • ...
  • 設計模式(Design Patterns) ——可復用面向對象軟體的基礎 設計模式(Design pattern)是一套被反覆使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。 毫無疑問,設計模式於己於他人於系統都是多贏的, ...
  • 前言 介紹java的常用集合+各個集合使用用例 歡迎轉載,請註明作者和出處哦☺ 參考: 1,《Java核心編程技術(第二版)》 2, "http://www.cnblogs.com/LittleHann/p/3690187.html" java 集合基本概念​​​​ 在《Java核心編程技術(第二版 ...
  • 總結 從畢業到現在工作差不多快半年了,其中做了公司官網的改版,工作彙報,分享樓盤的模塊,和網頁端安卓端對接,也認識到了交流的重要性,公司雖然小,但是包住宿這個還是很方便的,給剛來北京的我減輕了許多壓力. 我其實不想寫總結的,但是今天發生了一件事情,讓我寫了總結,以此來記錄下自己的心情感受,希望十年後 ...
  • ■ NPE 原因:thrift服務端可能停了 ■ org.apache.thrift.transport.TTransportException: Cannot write to null outputstream 原因:客戶端未調用transport的open()方法 ...
  • 1. 簡單瞭解模塊 寫的每一個py文件都是一個模塊. 還有一些我們一直在使用的模塊 buildins 內置模塊. print, input random 主要是和隨機相關的內容 random() 隨機小數 uninform(a,b) 隨機小數 randint(a,b) 隨機整數 choice() 隨 ...
  • 2018-12-26 今天是我正式學習Python的第二天,也是我準備用博客來記錄我學習歷程的第一天。希望可以堅持下去,並且真正學到一些東西。 對字元串進行操作的方法: 1.對輸入字元是否是數字的判斷{str.isdecimal(),str.isdigit(),str.isnumeric()} 由上 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...