HDU 5517---Triple(二維樹狀數組)

来源:http://www.cnblogs.com/chen9510/archive/2017/06/13/6995583.html
-Advertisement-
Play Games

題目鏈接 Problem Description Given the finite multi-set A of n pairs of integers, an another finite multi-set B of m triples of integers, we define the pr ...


題目鏈接

 

Problem Description Given the finite multi-set A of n pairs of integers, an another finite multi-set B of m triples of integers, we define the product of A and B as a multi-set

C=AB={a,c,da,bA, c,d,eB and b=e}

For each a,b,cC, its BETTER set is defined as

BETTERC(a,b,c)={u,v,wCu,v,wa,b,c, ua, vb, wc}

As a \textbf{multi-set} of triples, we define the TOP subset (as a multi-set as well) of C, denoted by TOP(C), as

TOP(C)={a,b,cCBETTERC(a,b,c)=}

You need to compute the size of TOP(C).
  Input The input contains several test cases. The first line of the input is a single integer t (1t10) which is the number of test case. Then t test cases follow.

Each test case contains three lines. The first line contains two integers n (1n105) and m (1m105) corresponding to the size of A and B respectively.
The second line contains 2×n nonnegative integers
a1,b1,a2,b2,,an,bn
which describe the multi-set A, where 1ai,bi105.
The third line contains 3×m nonnegative integers
c1,d1,e1,c2,d2,e3,,cm,dm,em
corresponding to the m triples of integers in B, where 1ci,di103 and 1ei105.
  Output For each test case, you should output the size of set TOP(C).   Sample Input 2 5 9 1 1 2 2 3 3 3 3 4 2 1 4 1 2 2 1 4 1 1 1 3 2 3 2 2 4 1 2 2 4 3 3 2 3 4 1 3 3 4 2 7 2 7 2 7 1 4 7 2 3 7 3 2 7 4 1 7   Sample Output Case #1: 5 Case #2: 12   題意:每組數據第一行輸入n m  ,第二行輸入a1 b1  a2  b2......an  bn,第三行輸入c1  d1  e1......cm  dm  em          現在定義C=A*B  即{<a,c,d>|<a,b>屬於A & <c,d,e>屬於B & b==e}         然後基於C有這樣一個運算TOP(C)={<a,c,d>|<a,c,d>屬於C & C中不存在<u,v,w>使得 u>=a,v>=c,w>=d,<u,v,w>!=<a,c,d> }         現在求 TOP(C)中有幾個元素?   思路:           

       上面是從論壇上截圖下來的,我覺得優化的時候,只需要用第一條即可,即:對於二元組(a,b) ,b相同的話只有最大的a值有效,所以對相同的b記錄一下最大值的個數

       第二條不一定能優化,在極端的數據上,一點都不會優化。經過第一條的優化後,C的大小為1e5,然後用二維樹狀數組處理O(n)=1e5*log2(1000)*log2(1000)=1e7

       實際的數據肯定會比這個複雜度要小。

 

代碼如下:

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
using namespace std;
const int N=1e5+5;
int a1[N],cnt[N];
int c[1005][1005];

struct Node
{
    int a,c,d;
    int v;
}tr[N];
int cmp(const Node s1,const Node s2)
{
    if(s1.a!=s2.a) return s1.a<s2.a;
    if(s1.c!=s2.c) return s1.c<s2.c;
    return s1.d<s2.d;
}
int lowbit(int x)
{
    return x&(-x);
}
int query(int x)
{
    int ans=0;
    int i=tr[x].c;
    while(i<1005)
    {
        int j=tr[x].d;
        while(j<1005)
        {
            ans+=c[i][j];
            j+=lowbit(j);
        }
        i+=lowbit(i);
    }
    return ans;
}
void update(int x)
{
    int i=tr[x].c;
    while(i>0)
    {
        int j=tr[x].d;
        while(j>0)
        {
            c[i][j]++;
            j-=lowbit(j);
        }
        i-=lowbit(i);
    }
}
int main()
{
    ///cout << "Hello world!" << endl;
    int t,Case=1;
    cin>>t;
    while(t--)
    {
       int n,m;
       scanf("%d%d",&n,&m);
       memset(a1,-1,sizeof(a1));
       memset(c,0,sizeof(c));
       for(int i=1;i<=n;i++)
      {
          int a,b;
          scanf("%d%d",&a,&b);
          if(a1[b]<a){
             a1[b]=a;
             cnt[b]=1;
          }
          else if(a1[b]==a) cnt[b]++;
      }
      int num=0;
      for(int i=1;i<=m;i++)
      {
          int c,d,e;
          scanf("%d%d%d",&c,&d,&e);
          if(a1[e]==-1) continue;
          tr[num].a=a1[e];
          tr[num].c=c;
          tr[num].d=d;
          tr[num++].v=cnt[e];
      }
      sort(tr,tr+num,cmp);
      int flag=0;
      int k=0;
      for(int i=1;i<num;i++)
      {
          if(tr[i].a==tr[k].a&&tr[i].c==tr[k].c&&tr[i].d==tr[k].d)
          {
              tr[k].v+=tr[i].v;
          }
          else{
             k++;
             flag=1;
             tr[k].a=tr[i].a;
             tr[k].c=tr[i].c;
             tr[k].d=tr[i].d;
             tr[k].v=tr[i].v;
          }
      }
      long long ans=0;
      if(flag)  ///防止 1 1 (1,1) (1,1,2) 這樣的數據(但是HDU上沒這樣的數據);
      for(int i=k;i>=0;i--)
      {
          if(!query(i)) ans+=(long long)tr[i].v;
          update(i);
      }
      printf("Case #%d: %lld\n",Case++,ans);
    }
    return 0;
}

 


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

-Advertisement-
Play Games
更多相關文章
  • ServerSuperIO以前所做的工作逐步為形成迴路控制或級聯控制打下基礎,例如:服務連接器和設備驅動連接器的開發與應用。總之,是通過多種形式下發命令控制設備(驅動)或感測器,雲端控制站點或監測點的感測器、App或者其他終端控制感測器、根據感測器的採集數據控制另一個感測器等。 ...
  • 現在辦公要流程化,營銷也有流程,流程現在已經是各種生活活動不可缺少的一部分了。就像這句耳熟能詳的話:“凡事,我們先走個流程嘛!”,在信息化、流程化的背景下。工作流引擎,這個名詞就出現了!那麼,什麼是工作流引擎呢?所謂工作流引擎是指workflow作為應用系統的一部分,併為之提供對各應用系統有決定作用 ...
  • 前段時間巨硬發佈了一款新的輸入設備Surface Dial,配合Surface Studio使用簡直炫酷到沒朋友。 本人由於公司業務有幸參與了微軟的相關培訓,最大的收穫覺得是發現WPF居然也可以開發Dial, WPF居然可以使用UWP的API! 不賣關子,關鍵就是名為“UwpDesktop”的一個N ...
  • Object中的公共方法解釋: 公共方法: Equals: public class Object { public virtual Boolean Equals(Object obj) { //如果兩個引用指向同一個對象,他們肯定包含相同的值 if (this == obj) return tru ...
  • 由於種種原因吧,我需要使用一個WPF程式起調一個UWP程式,下麵總結一下,給自己個備份。 啟動UWP程式的關鍵是協議啟動 給我們的UWP應用添加一個協議,like this: 然後使用協議啟動該UWP有一下幾種方式: 1. 使用UWP的Launcher API // Create the URI t ...
  • 背水一戰 Windows 10 之 控制項(集合類 - ItemsControl): 自定義 ItemsControl(自定義 GirdView 使其每個 item 占用不同大小的空間), 自定義 ContentPresenter 實現類似 GridViewItemPresenter 和 ListVi... ...
  • 前幾天需要在UWP中實現吸頂,就在網上找了一些文章: 吸頂大法 -- UWP中的工具欄吸頂的實現方式之一 在UWP中頁面滑動導航欄置頂 發現前人的實現方式大多是控制ListViewBase的Header變換高度,或者建立一個ScrollViewer在裡面放置ListViewBase。經過測試,這兩種 ...
  • 很多人在寫代碼的時候關於路徑這個問題很頭疼,其實路徑是很簡單的,只是沒人幫我們點投!初次學習程式的人,我相信肯定會遇到和我一樣的問題,比如說,“/”和“~”引用路勁的區別,接下來看吧,這篇文章肯定會將你點透的,看完這篇文章你一定會有一種山重水複疑無路,柳暗花明又一村的感覺! [註:]博主微信:jkx ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...