日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Weak Pair HDU - 5877 树状数组+离散化+DFS遍历

發布時間:2023/12/10 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Weak Pair HDU - 5877 树状数组+离散化+DFS遍历 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題意

  • 給我們一顆有根有向樹 以及每個點得權值a[1]~a[n] 需要我們求出在這顆樹種有多少對滿足以下兩個條件的pair
    (1)u是v的祖先節點 (2)a[u]*a[v]<= k
    N<=1e5
    a[i]<=1e9
    k<=1e18

分析

  • 由于需要在樹中找符合要求的對數 一般的算法恐怕比較慢 考慮條件等式 如果我們把等式化簡一下 可以得到a[u]<= k/a[v] 也就是說
    我們對于每個點 我們可以從樹中向上找祖先節點所有小于等于k/a[v]值的點的個數 也就是能和當前v點組成符合條件的對數
    關鍵是如何快速的求得我的祖先節點有多少個符合條件的個數呢? 如果建樹后從當前點向上遞歸 或是從根節點向下遞歸 向上遞歸每個節點
    都需要走所有的父親節點 最終的復雜度接近O(n^2) 從根節點向下遞歸 需要記錄每個節點的值 不好實現
    考慮如果我們把值元素插入到樹狀數組中 那么也就是說 每次對于當前節點我們只需要到 樹狀數組中查找有多少個點 滿足不能是要求不就行了嗎
    復雜度O(n*logn)
    那么如何保證查到的都是祖先節點呢 我們就需要從根節點開始dfs查找 每次對于一個新節點 我們查找符合條件的點 查完后把當前點插入進去 每次dfs回溯回來的時候就把該點的標記刪除掉 以防影響其他搜索枝的查找
    為何采用DFS這樣就能保證每次查找一個節點 所有的祖先節點以及查找插入過了
    那么關于1e9我們可以離散化為每次輸入的節點數量1e5
    為了使不等式大小關系不變 我們需要把每個節點的值和k/權值 也算作輸入數據的一部分
    因為只有這樣 才能保證相對大小不變 離散化后 仍然符合原來數值的大小關系

離散化:

void Discret(){sort(li+1,li+1+(n<<1));//對數組中每個元素的大小排名siz = unique(li+1,li+1+(n<<1))-li;//去重步驟 rep(i,1,n<<1)a[i] = lower_bound(li+1,li+1+siz,a[i])-li;// 查找排序去重后 原來的元素大小的位置賦值給原來的元素才能正確離散化 }

code

#include <iostream> #include <cstdio> #include <algorithm> #include <cstring> #include <queue> #include <vector>using namespace std; typedef long long ll; const int N = 1e5+10;ll a[N<<1],li[N<<1],k,ans; int tre[N<<1],n; int bok[N]; vector<int>e[N];void Discret(){for(int i=1;i<=n*2;i++)li[i] = a[i];sort(li+1,li+1+n*2);int siz = unique(li+1,li+1+n*2)-li-1;// unique 前提是有序數組for(int i=1;i<=n*2;i++)a[i] = lower_bound(li+1,li+1+siz,a[i])-li;// 只有查找排序去重后 拿原來的元素找位置才能正確離散化 } int sum(int x){int s=0;while(x>0){s+=tre[x];x-=x&(-x);}return s; } void add(int x,int val) {while(x<=n*2){tre[x]+=val;x+=x&(-x);} } void dfs(int rt) {ans+=sum(a[rt+n]);add(a[rt],1);for(int i=0;i<e[rt].size();i++)dfs(e[rt][i]);add(a[rt],-1); } int main() {int t;scanf("%d",&t);while(t--){ans=0;memset(tre,0,sizeof(tre));memset(bok,0,sizeof(bok));scanf("%d%lld",&n,&k);for(int i=1;i<=n;i++)e[i].clear();for(int (i)=1;(i)<=n;(i)++){scanf("%lld",&a[i]);if(a[i]==0)a[i+n]=1e18;else a[i+n]= k/a[i];}Discret();for(int i=1;i<n;i++){int u,v;scanf("%d%d",&u,&v);e[u].push_back(v);bok[v]++;}for(int i=1;i<=n;(i)++){if(!bok[i]){dfs(i);break;}}// 就是這忘記加括號了printf("%lld\n",ans);}return 0; }

WA了好幾十發 發現最后跳出循環的括號沒加WTF。。。寫代碼時還是最好不要擠在一行寫 容易眼缺。。。

總結

以上是生活随笔為你收集整理的Weak Pair HDU - 5877 树状数组+离散化+DFS遍历的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产中文字幕乱人伦在线观看 | 日本免费专区 | 成人污在线 | 人妻91麻豆一区二区三区 | 欧美精品一区二区免费看 | 91午夜视频在线观看 | 欧美成人精品一区二区三区在线看 | www.夜夜骑 | 永久视频| 日韩美女免费视频 | 一区三区在线观看 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 97国产精品视频人人做人人爱 | 美女交配 | 色葡萄影院 | www四虎 | 亚洲欧美中文字幕5发布 | xxx一区 | aaa成人 | 久久在线视频精品 | 亚洲在线视频播放 | 日本三级在线视频 | 污版视频在线观看 | 懂色一区二区三区免费观看 | 久久久久久伦理 | 午夜你懂的 | 一区二区成人免费视频 | 亚洲综合五月天婷婷丁香 | 日本呦呦| 成人玩具h视频 | 日韩在线免费看 | 精品人妻一区二区三区蜜桃 | 日韩专区一区 | 国产在线免费视频 | 97人人超| aaa在线视频 | 欧美日韩在线观看成人 | 国产小视频一区 | 成人毛片a | 手机看片日韩福利 | 成人免费av网站 | 亚洲一区二区小说 | 亚洲成熟少妇 | 欧美在线视频免费 | 国产日韩av在线播放 | 欧美成人做爰猛烈床戏 | 成年人在线视频网站 | 性渴老太作爱 | 欧美熟女一区二区 | 青草视频在线观看视频 | 在线看的免费网站 | 最新日韩av在线 | 中文字幕在线观看高清 | 精品国产一区二区三区在线 | 国产片淫乱18一级毛片动态图 | 91爱在线观看| 中文字幕av久久爽 | 亚洲av永久一区二区三区蜜桃 | 中文字幕一区二区不卡 | 欧美日韩生活片 | 精品日本一区二区 | 成人图片小说 | 91热精品 | 动漫av在线 | 亚洲精品一区二区三区蜜桃久 | 亚洲观看黄色网 | 精品视频亚洲 | 久久不卡影院 | 精品久久一区二区三区 | 精品在线观看视频 | 国产九九久久 | 久久久精品中文字幕麻豆发布 | 欧美人与性动交α欧美精品 | 黄网站免费入口 | 不许穿内裤随时挨c调教h苏绵 | 亚洲欧美另类图片 | 最新av片| 亚洲精品三级 | 国精产品一区一区三区在线 | 成人深夜电影 | 国产在线一区二区视频 | 91高清视频 | 欧美熟妇交换久久久久久分类 | 麻豆国产91在线播放 | 337p嫩模大胆色肉噜噜噜 | 在线成人播放 | 国产又粗又黄又爽又硬的视频 | 91视频免费播放 | 日韩欧美a级片 | 美女又黄又免费的视频 | 波多野结衣潜藏淫欲 | 91色在线播放 | 国产精品sm调教免费专区 | 丰满人妻一区二区三区精品高清 | 91免费高清视频 | 女人天堂网站 | 吃瓜网今日吃瓜 热门大瓜 色婷在线 | 一区二视频 | 美女色诱男人激情视频 |